社区
C++ 语言
帖子详情
一个很重要的问题--100分
My_QQ
2004-09-16 10:04:31
大家可能经常遇到这样的情况
T* p=new T[100000];
如果Delete p当然没问题
但我想只删除其中的一个时该如何办那
因为我不想一个一个的NEW
数据量大,太慢拉!!!
...全文
442
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)
数据库--
分
库
分
表--方案/切
分
方式/注意的
问题
包括:什么时候进行
分
库
分
表,
分
库
分
表的方式,
分
库
分
表需要注意的
问题
。 此技术也是Java后端面试中常见的
问题
。 什么时候
分
库
分
表 《阿里巴巴 Java 开发手册》: 单表行数超过 500 万行或者单表容量超过 2GB,...
算法-------过河经典
问题
,超详细解析
算法-------过河
问题
... 描述 一群N人希望用一条船过河,这条船最多只能载两个人。因此,必须安排某种穿梭安排,...你的工作是确定
一个
策略,尽量减少这些人的过河时间。 输入 输入的第一行包含
一个
整数T(1<...
0-1 背包
问题
的 4 种解决方法&&算法策略
0-1背包是
一个
经典的
问题
,而它能用不同的算法思想去解决。恰巧最近在看算法,学习算法就是学习解决
问题
的思路。现在将0-1背包
问题
与解决方法整理出来,这样不仅能区
分
不同的算法思想,还能加深对0-1背包
问题
的理解...
解读
分
库
分
表中间件Sharding-JDBC与实现
分
库
分
表功能
分
库
分
表适用场景
分
库
分
表用于应对当前互联网常见的两个场景——大数据量和...水平拆
分
则是根据
分
片算法将
一个
库(表)拆
分
为多个库(表)。如:按照ID的最后一位以3取余,尾数是1的放入第1个库(表),尾数是2的放...
遗传算法解决TSP
问题
MATLAB实现(详细)
问题
定义:巡回旅行商
问题
给定一组n个城市和俩俩之间的直达距离,寻找一条闭合的旅程,使得每个城市刚好经过一...TSP是
一个
具有广泛的应用背景和
重要
理论价值的组合优化
问题
。 近年来,有很多解决该
问题
的较为有效...
C++ 语言
64,648
社区成员
250,476
社区内容
发帖
与我相关
我的任务
C++ 语言
C++ 语言相关问题讨论,技术干货分享,前沿动态等
复制链接
扫一扫
分享
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++
技术论坛(原bbs)
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
请不要发布与C++技术无关的贴子
请不要发布与技术无关的招聘、广告的帖子
请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下
试试用AI创作助手写篇文章吧
+ 用AI写文章