新浪微博
腾讯微博
会员列表
统计排行
基本信息
到访IP统计
管理团队
管理统计
在线会员
会员排行
版块排行
帖子排行
标签排行
帮助
下拉
用户名
电子邮箱
用户名
密 码
记住登录
登录
找回密码
注册
快捷通道
关闭
您还没有登录,快捷通道只有在登录后才能使用。
立即登录
还没有帐号? 赶紧
注册一个
首页
论坛
Qt下载
作品展
群组
个人中心
捐赠、管理与开发
邮件订阅
帖子
文章
日志
用户
版块
群组
帖子
搜索
QTCN开发网
>
Qt基础编程
>
关于循环中的内存释放求助
发帖
回复
返回列表
新帖
6496
阅读
7
回复
关于循环中的内存释放求助
[复制链接]
上一主题
下一主题
离线
ldqiang
UID:42045
注册时间
2008-03-26
最后登录
2010-08-27
在线时间
10小时
发帖
38
搜Ta的帖子
精华
0
金钱
380
威望
39
贡献值
0
好评度
38
访问TA的空间
加好友
用道具
新手上路
关闭
个人中心可以申请新版勋章哦
立即申请
知道了
加关注
发消息
只看楼主
正序阅读
楼主
发表于: 2008-04-22
— 本帖被 XChinux 执行加亮操作(2008-04-22) —
请看下面代码:
char* buffer = NULL;
for(条件)//
{
int count = 通过外部数据计算出来; //每次循环分配的内存大小不一样
buffer = new char[ count];
if(条件)
{
操作buffer
delete []buffer;
buffer = NULL;
}
}
if( buffer != NULL)//防止产生内存泄漏
{
delete []buffer;
buffer = NULL;
}
这是在循环中释放了内存,外部做了一次检查
还有就是第二种:
char* buffer = NULL;
for(条件)//
{
int count = 通过外部数据计算出来; //每次循环分配的内存大小不一样
buffer = new char[ count];
if(条件)
{
操作buffer
}
}
if( buffer != NULL)//释放内存 {
delete []buffer;
buffer = NULL;
}
大家给点意见,哪种好一样,为什么?谢谢!
共
条评分
回复
举报
分享到
淘江湖
新浪
QQ微博
QQ空间
开心
人人
豆瓣
网易微博
百度
鲜果
白社会
飞信
离线
tkfly0324
UID:43005
注册时间
2008-04-17
最后登录
2012-03-06
在线时间
6小时
发帖
33
搜Ta的帖子
精华
0
金钱
330
威望
34
贡献值
0
好评度
33
访问TA的空间
加好友
用道具
新手上路
加关注
发消息
只看该作者
7楼
发表于: 2008-04-25
同意
共
条评分
回复
举报
离线
xjcook
UID:3676
注册时间
2006-02-13
最后登录
2018-01-16
在线时间
67小时
发帖
278
搜Ta的帖子
精华
0
金钱
2830
威望
284
贡献值
0
好评度
283
访问TA的空间
加好友
用道具
侠客
加关注
发消息
只看该作者
6楼
发表于: 2008-04-25
第一种本来是有泄露的,改成foxyz所说那样,应该没有了。
第二种本来的没有泄露。
我认为第二种好,因为只new一次,delete一次,效率要高些,
new次数非常频繁而且很多的话,是很浪费效率的。
如果个数不多,用的次数也不多的话,无所谓。
第一种有一个第二种没有的优势,就是可以根据不同情况new不同的东西,
如果new的东西不一样的时候只能用第一种。
共
条评分
回复
举报
离线
ldqiang
UID:42045
注册时间
2008-03-26
最后登录
2010-08-27
在线时间
10小时
发帖
38
搜Ta的帖子
精华
0
金钱
380
威望
39
贡献值
0
好评度
38
访问TA的空间
加好友
用道具
新手上路
加关注
发消息
只看该作者
5楼
发表于: 2008-04-25
感谢
共
条评分
回复
举报
离线
foxyz
UID:35172
注册时间
2007-08-31
最后登录
2020-05-07
在线时间
100小时
发帖
457
搜Ta的帖子
精华
0
金钱
4599
威望
458
贡献值
0
好评度
457
访问TA的空间
加好友
用道具
骑士
加关注
发消息
只看该作者
4楼
发表于: 2008-04-24
char* buffer = NULL;
for(条件)//
{
int count = 通过外部数据计算出来; //每次循环分配的内存大小不一样
buffer = new char[ count];
if(条件)
{
操作buffer
delete []buffer;
buffer = NULL;
}
}
if( buffer != NULL)//防止产生内存泄漏
{
delete []buffer;
buffer = NULL;
}
这是在循环中释放了内存,外部做了一次检查
%%这个肯定有泄漏!你分配的时候是在条件外边,delete的时候是在条件里边,虽然你在循环外增加了一次释放,但是你在循环粒很可能分配了多次!
改成:
char* buffer = NULL;
for(条件)//
{
int count = 通过外部数据计算出来; //每次循环分配的内存大小不一样
if(条件)
{
buffer = new char[ count];
操作buffer
delete []buffer;
buffer = NULL;
}
}
还有就是第二种:
char* buffer = NULL;
for(条件)//
{
int count = 通过外部数据计算出来; //每次循环分配的内存大小不一样
buffer = new char[ count];
if(条件)
{
操作buffer
}
}
if( buffer != NULL)//释放内存 {
delete []buffer;
buffer = NULL;
}
大家给点意见,哪种好一样,为什么?谢谢!
%%这个就更加要泄漏了,在循环里分配多次,只在循环外释放一次
改成:
char* buffer = NULL;
for(条件)//
{
int count = 通过外部数据计算出来; //每次循环分配的内存大小不一样
if(条件)
{
buffer = new char[ count];
操作buffer
delete []buffer;
buffer = NULL;
}
}
共
条评分
回复
举报
离线
gery_sunjian
UID:42312
注册时间
2008-04-01
最后登录
2009-06-28
在线时间
100小时
发帖
196
搜Ta的帖子
精华
0
金钱
1960
威望
197
贡献值
0
好评度
196
访问TA的空间
加好友
用道具
侠客
加关注
发消息
只看该作者
3楼
发表于: 2008-04-23
内存泄漏
第一个 中 的 后面那个释放
if( buffer != NULL)//防止产生内存泄漏
{
delete []buffer;
buffer = NULL;
}
只 释放了 最后 for 循环 分配的
我的见解/
共
条评分
回复
举报
离线
ldqiang
UID:42045
注册时间
2008-03-26
最后登录
2010-08-27
在线时间
10小时
发帖
38
搜Ta的帖子
精华
0
金钱
380
威望
39
贡献值
0
好评度
38
访问TA的空间
加好友
用道具
新手上路
加关注
发消息
只看该作者
2楼
发表于: 2008-04-22
感谢楼上的见解,但是第一个当失败后,后面做了内存检查,如果不为0就清除内存,然后给上0值。
共
条评分
回复
举报
离线
yuan5lai9
UID:42530
注册时间
2008-04-07
最后登录
2008-07-14
在线时间
19小时
发帖
13
搜Ta的帖子
精华
0
金钱
130
威望
14
贡献值
0
好评度
13
访问TA的空间
加好友
用道具
新手上路
加关注
发消息
只看该作者
1楼
发表于: 2008-04-22
我感觉都有内存泄露啊..
第一个,for循环 每次都有新分配内存空间啊,只有在if(条件)成立的时候才delete了,不成立的时候就丢掉了内存.
第二个MS泄露的更厉害吧,只delete掉了最后一个.
不知道是不是 这样的,高手来看看吧
共
条评分
回复
举报
发帖
回复
返回列表
http://www.qtcn.org/bbs
访问内容超出本站范围,不能确定是否安全
继续访问
取消访问
快速回复
限100 字节
您目前还是游客,请
登录
或
注册
进入高级模式
文字颜色
发 布
回复后跳转到最后一页
上一个
下一个
关闭
补充发布信息
验证码:
发 布
隐藏
快速跳转
站务及资讯
网站公告
新闻资讯
Qt官方发布
网站管理
Qt应用及资源
Qt 作品展
Qt代码秀
Qt应用版
Qt技术讨论区
Qt安装与发布
Qt中文处理
Qt基础编程
Qt QML开发
Qt嵌入式开发
Qt移动平台开发
其它技术开发讨论区
Qt图书专区
《C++ GUI Qt 4编程》(第2版)专栏
《Qt高级编程》专栏
《零基础学Qt4编程》专栏
《Qt设计模式》(第2版) 图书专栏
Python Qt GUI快速编程
Qt项目开发区
天池项目
Qt开放平台开发库
机械CAD
扇贝词典
非活跃项目区
社区中心
帖子回收站(Trash)
招聘、求职、供求、广告等
休闲娱乐
关闭
关闭
选中
1
篇
全选