社区
C++ 语言
帖子详情
一个很重要的问题--100分
My_QQ
2004-09-16 10:04:31
大家可能经常遇到这样的情况
T* p=new T[100000];
如果Delete p当然没问题
但我想只删除其中的一个时该如何办那
因为我不想一个一个的NEW
数据量大,太慢拉!!!
...全文
456
47
打赏
收藏
一个很重要的问题--100分
大家可能经常遇到这样的情况 T* p=new T[100000]; 如果Delete p当然没问题 但我想只删除其中的一个时该如何办那 因为我不想一个一个的NEW 数据量大,太慢拉!!!
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
47 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
cpunion
2004-09-16
打赏
举报
回复
当然是可以解决的,实际上你提到的是一个内存池的概念,一般用来解决数量比较多的小对象的连续分配,这要用到placement new,以下代码仅供参考:
#include <iostream>
#include <string>
using namespace std;
class Test
{
string str;
public:
Test (int n){char buf[20]; snprintf (buf, 20, "%d", n); str = buf; cout << "ctor:" << str << "\t";}
~Test () {cout << "dtor:" << str << "\t";}
};
Test的构造函数接受一个整数,主要是用来输出,也可以用来测试。
int main ()
{
int SIZE = 10000;
void* array = operator new[](SIZE * sizeof(Test)); //分配内存
Test* testArray = static_cast<Test*>(array); //强制转换,
for (int i=50; i<100; i++)
{
new (&testArray[i]) Test(i); //placement new,译成什么我也不知道,实际上就是在已有的堆内存上构造对象,后面的Test(i)是调用构造函数。
}
for (int j=99; j>=70; j--)
{
testArray[j].~Test(); // 因为内存是一起分配的,你无法调用delete来删除某一个,只可以析构。如果调用delete,后果无法预知。
}
//我分成2段循环,是让你看到我以不同的顺序来析构对象,并没有影响到什么。
for (int k=50; k<70; k++)
{
testArray[k].~Test();
}
operator delete[](array); //释放内存
return 0;
}
上面我分配了可以容纳10000个Test的内存,实际上只使用了其中的50个。
testArray[k].~Test();也可以写成testArray[k].Test::~Test();
brucegong
2004-09-16
打赏
举报
回复
kao
伤自尊了……我习惯用free……
My_QQ
2004-09-16
打赏
举报
回复
1
关于堆的管理,系统在背后做了很多工作,是它在浪费内存,
你可以查查资料
2
p =new T[];
for( i=0;i < 1 ; ++i )
{
delete p++;
}
时,你的内存应该已经没有了
3 大家有办法的就多多指教,不知道的也多想想
不要把话题扯远了
umbrella1984
2004-09-16
打赏
举报
回复
我定义了一个二维数组,怎么循环显示数组值?
for(int ii=0;ii<20;ii++){
a[ii]=new int[ii];
}
for(int iii=0;iii<2;iii++){
for(int iiii=0;iiii<20;iiii++){
cout<<*a[iiii]<<endl;
nicknide
2004-09-16
打赏
举报
回复
freshairfly(菜鸟精神):
brucegong(飞行猪)
为什么不给每一个指针设置一个标志?
----------------------------
我当然知道这个问题可以解决。
首先,飞行猪啊,你都已经把那个地方删除了,然后还去访问,有可能产生非法访问啊(操作系统把那个空页给回收了,你访问就得到一个致命的调页失败错误,如果没有用SEH,直接程序就DOWN了……
菜鸟精神啊,你还要有认真精神才好,也要想一想再说嘛……
freefalcon
2004-09-16
打赏
举报
回复
楼主先说清楚需求
为何要一次new这么多对象
为何又要在某个时刻删除一个
freshairfly
2004-09-16
打赏
举报
回复
而且我要尽量减少内存的使用,
一个一个的NEW时,在堆里事实上浪费了好多字节的RAM啊
-----------------------------------
一起new就不会浪费内存了吗?
daylove
2004-09-16
打赏
举报
回复
好象是有点不对,
那个:for( i=0;i < 10000 ; ++i )
{
delete p++;
}
这里可以一个个删除吗?不明白,
楼主也没有必要指定删除某个啊,等你最后不用时,整个delete [] p;不就可以了???
freshairfly
2004-09-16
打赏
举报
回复
for(i = 0; i < 100000; ++i)
{
delete p++;
}
有问题啊!!想想吧!
---------------------------
有什么问题就说出来,不要装作很高深的样子!!
还有你到底要问的什么问题,怎么一会儿“只删除其中的一个”
一会儿“FOR()要一个一个的NEW,太慢了”
麻烦说清楚,OK?
freshairfly
2004-09-16
打赏
举报
回复
brucegong(飞行猪)
为什么不给每一个指针设置一个标志?
----------------------------
我当然知道这个问题可以解决。
darkstar21cn
2004-09-16
打赏
举报
回复
for(i = 0; i < 100000; ++i)
{
delete p++;
}
是错误的
freshairfly
2004-09-16
打赏
举报
回复
T* p=new T[100000];
delete[] p;
for(i = 0; i < 100000; ++i)
{
delete p++;
}
这里有问题吧?上面已经delete[] p;了怎么下面还delete p++;?
-----------------------------------------------------------------
我的意思是两种delete方法。楼主说需要只delete一部分,第二种方法就可以
umbrella1984
2004-09-16
打赏
举报
回复
T* p=new T[100000];
delete[] p;
for(i = 0; i < 100000; ++i)
{
delete p++;
}
这里有问题吧?上面已经delete[] p;了怎么下面还delete p++;?
My_QQ
2004-09-16
打赏
举报
回复
好,你有好办法,
多多指教!
brucegong
2004-09-16
打赏
举报
回复
在一个那么在意内存的系统里面还用常规方式来new delete??
奢侈
内存紧张的系统都是自己管理内存的,根本不是用new delete
brucegong
2004-09-16
打赏
举报
回复
freshairfly(菜鸟精神)
为什么不给每一个指针设置一个标志?
struct Point_Struct
{
BOOL bUse;
T* pPointer;
};
struct Point_Struct p[10000];
for()
{
...
p[i].bUse = TRUE;
...
}
delete的时候置为false或者……或者将指针置空……总之方法太多了
程序员是无所不能的
My_QQ
2004-09-16
打赏
举报
回复
for(i = 0; i < 100000; ++i)
{
delete p++;
}
有问题啊!!想想吧!
My_QQ
2004-09-16
打赏
举报
回复
而且我要尽量减少内存的使用,
一个一个的NEW时,在堆里事实上浪费了好多字节的RAM啊
My_QQ
2004-09-16
打赏
举报
回复
朋友,我不是说了,FOR()要一个一个的NEW,太慢了
我连续NEW 400000个30BYTE 的类时,程序就没反映了
指针的指针还可以考虑
freshairfly
2004-09-16
打赏
举报
回复
T* p=new T[100000];
delete[] p;
for(i = 0; i < 100000; ++i)
{
delete p++;
}
我觉得这样可以delete them one by one
不过如果你选中几个删除后,以后你就不知道哪几个被删除了。
加载更多回复(27)
1762962472073755_00d2.mobileconfig
1762962472073755_00d2.mobileconfig
水果商城销售系统(源码+数据库+毕业论文+答辩ppt)java开发springboot框架javaweb,可做计算机毕业设计或课程设计
水果商城销售系统(源码+数据库+毕业论文+答辩ppt)java开发springboot框架javaweb,可做计算机毕业设计或课程设计 【功能需求】 本系统
分
为用户、商家、管理员3个角色 ① 普通用户:注册登录后,可以通过在线查看公告资讯并进行收藏、点赞以及评论,浏览水果信息页面,搜索水果名称或根据
分
类筛选,加入购物车,编辑收件地址,确定购买下单并支付金额,查看订单状态,如有任何疑问可以咨询在线客服等功能。 ② 商家用户:在线注册后由管理进行审核后可以登录,商家可以发布水果信息,上传水果名称、图片、价格信息等,处理订单等功能。 ③ 管理员:具备对用户、商家、水果信息、水果
分
类、系统管理、订单管理等所有管理功能的权限。 【环境需要】 1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的 2.IDE环境:IDEA,Eclipse,Myeclipse都可以 3.tomcat环境:Tomcat 7.x,8.x,9.x版本均可 4.数据库:MySql 5.7/8.0等版本均可 【购买须知】 本源码项目经过严格的调试,项目已确保无误,可直接用于课程实训或毕业设计提交。里面都有配套的运行环境软件,讲解视频,部署视频教程,一应俱全,可以自己按照教程导入运行。附有论文参考,使学习者能够快速掌握系统设计和实现的核心技术。
LTP中文文本处理指南[源码]
这篇博客详细介绍了如何使用LTP(语言技术平台)进行中文文本处理,包括
分
词、词性标注和关键词提取。通过
一个
具体的代码案例,作者深入浅出地解释了中文
分
词的
重要
性及其在自然语言处理中的应用。博客还提供了环境准备的详细步骤,包括下载模型文件和安装必要的Python包。此外,作者还逐行解析了代码,解释了每个函数的作用和实现逻辑,帮助新手理解中文文本处理的核心技术。最后,博客探讨了
分
词技术在搜索引擎、机器翻译和智能客服等领域的实际应用,并推荐了进一步学习的资源。
Java内部类详解[代码]
本文详细介绍了Java内部类的相关知识,包括内部类的定义、使用原因及四种类型(成员内部类、静态内部类、局部内部类、匿名内部类)的具体使用方法。文章通过代码示例展示了每种内部类的特点和使用场景,并总结了内部类的优点,如独立继承、更好的封装性等。此外,还探讨了局部内部类和匿名内部类的使用限制,如局部变量的访问限制和匿名内部类的构造方法缺失等。全文内容详实,适合Java开发者深入学习内部类的使用。
三级食物链matlab仿真程序
三级食物链matlab仿真程序
C++ 语言
65,206
社区成员
250,519
社区内容
发帖
与我相关
我的任务
C++ 语言
C++ 语言相关问题讨论,技术干货分享,前沿动态等
复制链接
扫一扫
分享
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++
技术论坛(原bbs)
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
请不要发布与C++技术无关的贴子
请不要发布与技术无关的招聘、广告的帖子
请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下
试试用AI创作助手写篇文章吧
+ 用AI写文章