memset函数常用来初始化内存的数据,比如memset(data,0x00,sizeof(date))等,我让一个同事写了一个函数接口,用来解码二进制文件,当我进入代码合入的时候,发现
该接口函数执行到return 0语句之后就奔溃了,gdb之后发现没有多余的信息,只提示#0 0x0000000000000000 in ?? (),我百思不得其解,最重要的是,如果函数在单个进程里调用,不会发现该问题,执行成功,而我的程序是多线程,在多线程里就会崩溃。由于没有崩溃的具体位置,只能一个个排除用到内存的函数了,后来发现
有个变量定义为,char ipadd[3][50];然后用memset(ipadd,0x00,500);进行初始化,500超出了ipadd的长度范围,导致内存要回收的时候,有部分的数据无法处理,导致崩溃。看来线程的内存管理还是更复杂严格。因为一个不经意的小错误,浪费了许多宝贵的时间。
内存有多长就初始化为多长,如果超过规定的长度,那么超出的部分就没有安全的保证,很可能其他的线程刚好访问到这个,而导致崩溃!