lzc6996 2015-08-04 13:28 采纳率: 0%
浏览 1618

C++多线程外部排序的程序报错 bad allocaltion

http://www.cnblogs.com/Jedimaster/archive/2013/11/17/3427761.html
按照这个网页给的方法,写多线程的外部排序算法。我先用第一个产生数据的算法 产生了429496729个int大小的数据。整个文件大概有1.59G这么大。然后分成4个进程,来处理数据。在main函数中,将iNumLocalItems设置为 20 * 1024 * 1024以及更小没有任何错误,但是大一点比如30 * 1024 * 1024时就会出现bad allocaltion的错误。实在不知道该怎么调试了,求大神帮助。iNumLocalItems应该就是网页中提到的每个Job的大小。

产生数据的的程序第一个参数 argv[0]是文件地址,第二个参数argv[1]是希望产生多少个int 我在实验中用的429496729。

主程序的main函数的参数argv[0]是刚才产生的数据地址,argv[1]是线程数,argv[2]是job的大小,这里用20*1024*1024的时候没有问题,再大了就会产生 bad allocaltion的错误,不会有任何文件输出。

到底怎么回事,不太会调试多线程的程序,还请各位大神指点。

  • 写回答

1条回答 默认 最新

  • threenewbee 2015-08-04 13:42
    关注

    默认32bit的C++程序只能使用2GB内存。

    评论

报告相同问题?

悬赏问题

  • ¥15 lammps拉伸应力应变曲线分析
  • ¥15 C++ 头文件/宏冲突问题解决
  • ¥15 用comsol模拟大气湍流通过底部加热(温度不同)的腔体
  • ¥50 安卓adb backup备份子用户应用数据失败
  • ¥20 有人能用聚类分析帮我分析一下文本内容嘛
  • ¥15 请问Lammps做复合材料拉伸模拟,应力应变曲线问题
  • ¥30 python代码,帮调试
  • ¥15 #MATLAB仿真#车辆换道路径规划
  • ¥15 java 操作 elasticsearch 8.1 实现 索引的重建
  • ¥15 数据可视化Python