malloc (0x100000 - n)大小的内存,memset时传入大小为0x100000,报double free or corruption (!prev),定位方法如下:
第一步:valgrind --lead-check=full --show-leak-kinds=all --undef-value-errors=no --log-file=log a.out
第二步:然后查看生成的log文件
第三步:从log文件中找到Invalid read of size 这样的字样,可以看到哪行有问题;
同样的,free两次同一个地址,valgrind可以抓到Invalid free()/ delete /delete[] /realloc() 这样的log ps:使用 gdb 也可以轻松的定位到