这里是使用vector容器,这样的报错也适用其他数据类型报同样的错误
出现这样报错的原因是我程序使用这个location_entropy全局变量,程序中间有一个局部变量eNode赋值到了location_entropy。原因在于程序在for循环结束后就会释放eNode,而location_entropy因为是全局变量,程序结束后释放,所以导致释放了两次eNode变量。主要还是push_back是引用,使用emplace_back就会完全复制eNode到location_entropy中,相当于另一个空间,不会因为eNode空间释放导致后面程序结束释放后两次释放同一个空间。
typedef struct
{
int totalVisitNum;//保存访问该点的总数
int tasksNum;
int workersNum;
}entropyNode;
void test(){
for (int i = 0; i < gridPer.x*gridPer.y; i++)
{
entropyNode eNode;
eNode.totalVisitNum=0;
eNode.tasksNum=0;
eNode.workersNum=0;
location_entropy.push_back(eNode);//问题出在这一句
}
}
提醒大家使用全局变量时候,注意局部变量和全局变量释放的顺序
具体报错日志如下:
*** Error in `./WaterFilling': double free or corruption (out): 0x000000000041a4d0 *** ======= Backtrace: ========= /lib64/libc.so.6(+0x81329)[0x2aaaab25a329] /lib64/libc.so.6(+0x39ce9)[0x2aaaab212ce9] /lib64/libc.so.6(+0x39d37)[0x2aaaab212d37] /lib64/libc.so.6(__libc_start_main+0xfc)[0x2aaaab1fb55c] ./WaterFilling[0x402484] ======= Memory map: ======== 00400000-00402000 r--p 00000000 08:11 266602910 /home/jyj/workSpace/crowd/TOBM/algorithm/WaterFilling 00402000-00404000 r-xp 00002000 08:11 266602910 /home/jyj/workSpace/crowd/TOBM/algorithm/WaterFilling 00404 ffffffffff600000-ffffffffff601000 r-xp 00000000 00:00 0 [vsyscall] Aborted (core dumped)



