问题描述
- 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的错误,不会有任何文件输出。
到底怎么回事,不太会调试多线程的程序,还请各位大神指点。
解决方案
默认32bit的C++程序只能使用2GB内存。
时间: 2024-10-26 05:46:36