suwei95
2020-04-25 21:55
采纳率: 50%
浏览 539

new一个string字符串,然后用c_str(),转换为char*,最后用delete释放报错

const char* child=(new std::string("I am child"))->c_str();
delete child;

delete child报错

*** Error in `./a.out': munmap_chunk(): invalid pointer: 0x0000000001334040 ***
======= Backtrace: =========
/lib/x86_64-linux-gnu/libc.so.6(+0x777e5)[0x7f64bd0737e5]
/lib/x86_64-linux-gnu/libc.so.6(cfree+0x1a8)[0x7f64bd080698]
./a.out[0x400ee5]
/lib/x86_64-linux-gnu/libc.so.6(__libc_start_main+0xf0)[0x7f64bd01c830]
./a.out[0x400ca9]
======= Memory map: ========
00400000-00402000 r-xp 00000000 08:01 668164                             /home/jer/tmp/suwei/PKP/a.out

这个原因是不是new的时候系统自动生成了一个string*,赋值完成后,string*变量就自动释放,然后child不算是new出来的指针,而是一个普通指针。
还有为什么delete的一定要是new出来的指针,如果是delete普通指针就会报错呢?

  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

3条回答 默认 最新

  • Iambinary 2020-04-26 08:03
    已采纳

    你分配了一个空间存放

    new std::string("I am a child")
    //记作字符串str
    

    但你存储了str.c_str(),所以,你懂的,在堆上分配的指针才能释放。

    malloc() calloc() realloc() 配 free()
    new 配 delete
    
    已采纳该答案
    打赏 评论
  • threenewbee 2020-04-26 00:18

    这不废话么,delete必须和new配对
    c_str()并没有申请新的空间

    打赏 评论
  • 「已注销」 2020-04-26 05:29

    你new出来的对象是std::string("I am child"),然后你又调了c_str(), 也就是说你的指针接收的是c_str()的结果而不是new出来的那个,自然不能delete

    打赏 评论

相关推荐 更多相似问题