vector有bug?

从来不作 2014-05-09 04:35:25
不多说,直接上代码:
#include <iostream>
#include <vector>
using namespace std;
int main()
{
    vector<vector<float>> wjz;
    vector<float> w;
    for (int j=0;j<300;++j)
    {
        w.resize(1000000);
        for (int i=0;i<1000000;++i)
        {
            w.push_back(i);
        }

        wjz.push_back(w);
        cout<<"current_size:"<<wjz.size()<<endl;
    }
    return 0;

}

运行会出错,而把其中的resize操作换成clear就没问题,这是不是一个bug?
...全文
132 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
从来不作 2014-05-09
  • 打赏
  • 举报
回复
引用 2 楼 jianwen0529 的回复:
好好看书,骚年!!
恩恩,必须的
从来不作 2014-05-09
  • 打赏
  • 举报
回复
引用 5 楼 Fire_Lord 的回复:
这不是bug, 而是楼主没有理解 resize 的含义以及在 32 位平台下用户进程地址空间的大小。请看下面代码注释部分:

#include <iostream>
#include <vector>
using namespace std;
int main()
{
	vector<vector<float>> wjz;
	vector<float> w;
	for (int j=0;j<300;++j)
	{
		w.resize(1000000);	//调用resize,使得w的size为1000000 个float
		for (int i=0;i<1000000;++i)
		{
			w.push_back(i); //插入1000000 个float
		}
		//此时w 的size 为 2000000 个float

		wjz.push_back(w);
		cout<<"current_size:"<<wjz.size()<<endl;
	}
	return 0;

}
假设程序能够正确运行,那么在运行结束后,wjz 至少需要内存 2000000 * 300 *sizeof(float) = 2.288GB Win32程序在通常情况下用户内存空间为2G,因此楼主的程序是引发了内存不足的异常。 之所以使用clear 就没问题了,是因为每次向wjz 只插入1000000 个float, 总内存为 1.144G,没有导致内存不足的情况。
谢谢回复,发现自己不懂的地方还有很多,得好好看书了。
Fire_Lord 2014-05-09
  • 打赏
  • 举报
回复
这不是bug, 而是楼主没有理解 resize 的含义以及在 32 位平台下用户进程地址空间的大小。请看下面代码注释部分:

#include <iostream>
#include <vector>
using namespace std;
int main()
{
	vector<vector<float>> wjz;
	vector<float> w;
	for (int j=0;j<300;++j)
	{
		w.resize(1000000);	//调用resize,使得w的size为1000000 个float
		for (int i=0;i<1000000;++i)
		{
			w.push_back(i); //插入1000000 个float
		}
		//此时w 的size 为 2000000 个float

		wjz.push_back(w);
		cout<<"current_size:"<<wjz.size()<<endl;
	}
	return 0;

}
假设程序能够正确运行,那么在运行结束后,wjz 至少需要内存 2000000 * 300 *sizeof(float) = 2.288GB Win32程序在通常情况下用户内存空间为2G,因此楼主的程序是引发了内存不足的异常。 之所以使用clear 就没问题了,是因为每次向wjz 只插入1000000 个float, 总内存为 1.144G,没有导致内存不足的情况。
赵4老师 2014-05-09
  • 打赏
  • 举报
回复
mujiok2003 2014-05-09
  • 打赏
  • 举报
回复
等价代码:
#include <iostream>
#include <vector>
using namespace std;
int main()
{
    vector<vector<float>> wjz;
    vector<float> w;
     w.resize(2000000);
     for (int i=0;i<1000000;++i)
        {
            w[i+1000000] = i;
        }
    for (int j=0;j<300;++j)
    {    
        
 
        wjz.push_back(w);
        cout<<"current_size:"<<wjz.size()<<endl;
    }
    return 0;
 
}
幻夢之葉 2014-05-09
  • 打赏
  • 举报
回复
好好看书,骚年!!
mujiok2003 2014-05-09
  • 打赏
  • 举报
回复
引用
void resize(size_type sz, const T& c); Effects: if (sz > size()) insert(end(), sz-size(), c); else if (sz < size()) erase(begin()+sz, end()); else ;
也就是说resize只改变size,没有释放内存。

65,208

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧