免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 7276 | 回复: 13
打印 上一主题 下一主题

关于vector的push_back的内存增涨问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-01-10 13:35 |只看该作者 |倒序浏览
  1.   1 #include  <vector>
  2.   2 #include  <map>
  3.   3 #include  <string>
  4.   4 #include  <cstdio>
  5.   5 #include  <ctime>
  6.   6 #include  <iostream>
  7.   7
  8.   8 using namespace std;
  9.   9
  10. 10 template<class X>
  11. 11 void tryFun(X& haha)
  12. 12 {
  13. 13     int i=1;
  14. 14     cout<<haha<<endl;
  15. 15 }
  16. 16
  17. 17 int main(int argc, char *argv[])
  18. 18 {
  19. 19     clock_t start=clock();
  20. 20     map<string,int> aaa;
  21. 21     char str[100];//内存使用0%
  22. 22     
  23. 23     for( int i=0 ; i<10000000 ; ++i )
  24. 24     {
  25. 25         sprintf(str,"abcaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa%d",i);
  26. 26         aaa[str]=1;
  27. 27     }   
  28. 28     map<string,int>::iterator it=aaa.begin();//内存使用19.6%
  29. 29     vector<string> abc;
  30. 30     for( int i=0 ; i<10000000 ; ++i )
  31. 31     {
  32. 32         abc.push_back(it->first);
  33. 33         ++it;
  34. 34     }   
  35. 35     
  36. 36     
  37. 37     cout<<(clock() - start)/1000<<endl;//内存使用20%
  38. 38 EXIT:
  39. 39     cout<<"aaaa"<<endl;
  40. 40     return 0;
  41.   }
复制代码
为什么vector的push_back几乎没有增加内存?

论坛徽章:
14
巨蟹座
日期:2013-11-19 14:09:4615-16赛季CBA联赛之青岛
日期:2016-07-05 12:36:0515-16赛季CBA联赛之广东
日期:2016-06-29 11:45:542015亚冠之全北现代
日期:2015-07-22 08:09:472015年辞旧岁徽章
日期:2015-03-03 16:54:15巨蟹座
日期:2014-12-29 08:22:29射手座
日期:2014-12-05 08:20:39狮子座
日期:2014-11-05 12:33:52寅虎
日期:2014-08-13 09:01:31巳蛇
日期:2014-06-16 16:29:52技术图书徽章
日期:2014-04-15 08:44:01天蝎座
日期:2014-03-11 13:06:45
2 [报告]
发表于 2011-01-10 13:41 |只看该作者
为什么vector的push_back几乎没有增加内存?
---------
当 size() < capacity() 时不需要重新分配内存

论坛徽章:
324
射手座
日期:2013-08-23 12:04:38射手座
日期:2013-08-23 16:18:12未羊
日期:2013-08-30 14:33:15水瓶座
日期:2013-09-02 16:44:31摩羯座
日期:2013-09-25 09:33:52双子座
日期:2013-09-26 12:21:10金牛座
日期:2013-10-14 09:08:49申猴
日期:2013-10-16 13:09:43子鼠
日期:2013-10-17 23:23:19射手座
日期:2013-10-18 13:00:27金牛座
日期:2013-10-18 15:47:57午马
日期:2013-10-18 21:43:38
3 [报告]
发表于 2011-01-10 13:45 |只看该作者
string对象本身也不大吧

论坛徽章:
0
4 [报告]
发表于 2011-01-10 13:47 |只看该作者
回复 2# bruceteen


    我没有给vector预分配内存啊

论坛徽章:
0
5 [报告]
发表于 2011-01-10 13:49 |只看该作者
回复 3# hellioncu

直接push_back(string)能涨10%啊

论坛徽章:
0
6 [报告]
发表于 2011-01-10 14:03 |只看该作者
内存使用19%、20%,这个数据是怎样测量的,贴出原始数据?

论坛徽章:
0
7 [报告]
发表于 2011-01-10 14:07 |只看该作者
回复 6# drangon


    用top肉眼看的啊

论坛徽章:
0
8 [报告]
发表于 2011-01-10 14:31 |只看该作者
string进行拷贝时,如果不做内容改变,会使用同一块内存,如果内容有改变,才会重新申请空间,所以lz的push_back内存没有明显增长

论坛徽章:
0
9 [报告]
发表于 2011-01-10 14:43 |只看该作者
在push_back后
放入:
41     for( int i=0 ; i<10000000 ; ++i )
42     {
43         abc[i] = "abcaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa";
44     }


你就看到内存暴涨了

论坛徽章:
0
10 [报告]
发表于 2011-01-10 14:44 |只看该作者
为什么vector的push_back几乎没有增加内存?
earl808 发表于 2011-01-10 13:35



    所以,vector和数组一样,不会出现节省空间的
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP