在运行的时候出现了这个错误:
*** glibc detected *** /home/zyj/zk_lock/.libs/lt-zklocktest: free(): invalid pointer: 0x00000000004106d0 ***
开始啥都不明白,只是觉得哪里的free估计除了问题,在网上查了一系列资料后,开始着手来解决。
首先需要定位程序里的哪个free函数出的问题,由于程序里面用到free的地方不多,而且在执行过程中都有打印信息,所以很容易确定大概会在哪个free出错,最简单的办法就是在free的前面加上一个printf语句,这样就明确了。
网上有关于这个错误比较系统的解释:http://www.cnblogs.com/colorfulkoala/archive/2012/09/12/2682601.html
根据自己的情况就应该是invalid pointer,我把这个指针的内容打印出来,发现很正常,然后就从头跟踪这个指针。
原来开始并没有给这个指针分配空间,是将一个指针赋给它的,因此最后我们也不需要给这个指针进行释放,在注释掉这个free语句后就OK了。