我来我网
https://5come5.cn
 
您尚未 登录  注册 | 菠菜 | 软件站 | 音乐站 | 邮箱1 | 邮箱2 | 风格选择 | 更多 » 
 

本页主题: 一个C++里资源管理的小问题 显示签名 | 打印 | 加为IE收藏 | 收藏主题 | 上一主题 | 下一主题

zhoubaozhou





性别: 帅哥 状态: 该用户目前不在线
等级: 栋梁之材
发贴: 696
威望: 0
浮云: 1082
在线等级:
注册时间: 2007-03-13
最后登陆: 2023-01-26

5come5帮你背单词 [ single /'siŋgl/ a. 单个的,单一的,独身的,每个的,个别的;vt. 挑选 ]


一个C++里资源管理的小问题

刚刚在写一小程序,发现了一个问题,弄了半天,才发现自已错在哪
共享一下。
下面是问题的简化

int main(int argc, char **argv)
{
    char *p = new char[sizeof("hello,world")];
    strcpy(p,"hello,world");
    delete[] p;

    return 0;
}
运行后,会出现错误,不能执行下去。
跟踪了后现在delete 这里出问题了。
开始不思其解
如果去掉strcpy(p,"hello,world");这一句问题就没了
跟踪delete发现确实是里面错了。
后来改了一下
char *p = new char[sizeof("hello,world") + 1];
问题解决了。

思考:
开始一直以为delete这个语句执行时会查new 申请的情况,然后再来delete
但是却发现没有,如 delete字符串只是 delete 到字符串的0x0处。
这样的内存管理应该是存在问题的,可能会造成内在泄露,或都出现我上面的问题。
如果用查表技术,每次new时把其申请的内存地址及申请空间大小存入一个表中
下次delete时只要查一下表就可以不会造成上面的问题了。

当然这样效率可能会低一点。估计是C++将这个问题丢给用户自已去解决了。

刚刚接触C++,以前都是用C的。
看来C++的博大不是一会就能体会得到了。


[ 此贴被zhoubaozhou在2007-08-23 21:36重新编辑 ]
顶端 Posted: 2007-08-23 20:56 | [楼 主]
kangtalc



性别: 帅哥 状态: 该用户目前不在线
头衔: 揍敌客·奇犽
等级: 希望之光
家族: 万人坑恋影部落
发贴: 1723
威望: 5
浮云: 1113
在线等级:
注册时间: 2005-09-21
最后登陆: 2008-06-29

5come5帮你背单词 [ outdoor /'autdo:/ a. 户外的,露天的,野外的 ]


这其实根本就不是DELETE的问题啊
其实问题出在strcpy
你申请的内存空间只有11字节,因为sizeof是不会算\0的
strcpy中的源字符串常量"hello,world"是12个字节(外加一个\0)
你用12个字节的字符串常量复制到只有11个字节的空间中当然会出错
而且这个和CPP没有什么关系吧,你用C应该一样会出错
顶端 Posted: 2007-08-23 21:11 | [1 楼]
kangtalc



性别: 帅哥 状态: 该用户目前不在线
头衔: 揍敌客·奇犽
等级: 希望之光
家族: 万人坑恋影部落
发贴: 1723
威望: 5
浮云: 1113
在线等级:
注册时间: 2005-09-21
最后登陆: 2008-06-29

5come5帮你背单词 [ gene // n. 基因,遗传因了 ]


Quote:
引用第4楼chenyukang于2007-08-23 21:16发表的  :

strcpy会自动增加一个换行?


不是换行啊,是\0要占一个字节的啊,因为要复制的'hello,world"是个字符串常量,加上个\0就是12字节啊
但是new的那个sizeof只算了11个字节啊,没有算上\0,所以要sizeof之后+1为\0留一个字节就不会出错了嘛
顶端 Posted: 2007-08-23 21:18 | [2 楼]
kangtalc



性别: 帅哥 状态: 该用户目前不在线
头衔: 揍敌客·奇犽
等级: 希望之光
家族: 万人坑恋影部落
发贴: 1723
威望: 5
浮云: 1113
在线等级:
注册时间: 2005-09-21
最后登陆: 2008-06-29

5come5帮你背单词 [ dog /dog/ n. 狗 ]


Quote:
引用第7楼zhoubaozhou于2007-08-23 21:19发表的  :


它会复制完0x0才停止,

所有就会出错啊,因为你的目的缓冲区的大小都不够
顶端 Posted: 2007-08-23 21:20 | [3 楼]
kangtalc



性别: 帅哥 状态: 该用户目前不在线
头衔: 揍敌客·奇犽
等级: 希望之光
家族: 万人坑恋影部落
发贴: 1723
威望: 5
浮云: 1113
在线等级:
注册时间: 2005-09-21
最后登陆: 2008-06-29

5come5帮你背单词 [ parliament /'pa:ləmənt/ n. 议会,国会 ]


Quote:
引用第7楼zhoubaozhou于2007-08-23 21:20发表的  :

它会复制完0x0才停止,


你也说了sizeof+1就对了多嘛
顶端 Posted: 2007-08-23 21:21 | [4 楼]
kangtalc



性别: 帅哥 状态: 该用户目前不在线
头衔: 揍敌客·奇犽
等级: 希望之光
家族: 万人坑恋影部落
发贴: 1723
威望: 5
浮云: 1113
在线等级:
注册时间: 2005-09-21
最后登陆: 2008-06-29

5come5帮你背单词 [ nominate /'nomineit/ v. 提名 ]


Quote:
引用第10楼zhoubaozhou于2007-08-23 21:22发表的  :

cout<<sizeof("hello,world")<<endl;
是12没错
sizeof会算到0x0


不会吧。。。。难道是我编译器的问题。。。
顶端 Posted: 2007-08-23 21:22 | [5 楼]
kangtalc



性别: 帅哥 状态: 该用户目前不在线
头衔: 揍敌客·奇犽
等级: 希望之光
家族: 万人坑恋影部落
发贴: 1723
威望: 5
浮云: 1113
在线等级:
注册时间: 2005-09-21
最后登陆: 2008-06-29

5come5帮你背单词 [ cosy /'kouzi/ a. 暖和舒服的,(感觉)舒适的 ]


Quote:
引用第18楼zhoubaozhou于2007-08-23 21:39发表的  :


不是,诡异的C++
还是去研究一下它的实现算了。
我估计是new会在申请的结尾标上一个标识符,
.......


不知道。。。。。
顶端 Posted: 2007-08-23 21:44 | [6 楼]
我来我网·5come5 Forum » 程序员之家

Total 0.010862(s) query 6, Time now is:11-23 08:06, Gzip enabled
Powered by PHPWind v5.3, Localized by 5come5 Tech Team, 黔ICP备16009856号