由于项目需要,程序在运行以后不知道结构体数组大小,需要用指针动态分配,测试过程中发现程序出现段错误,gdb调试内核打印信息如上,提示free掉了错误的内存。加入打印看到申请的内存首地址和free的内存首地址一直,进入误区,仔细看代码发现malloc(NsIec104Struct->TableChannel.Yx_num*sizeof(Struct_Yxn_T *))的大小不对,应该是结构体的大小不应该是指针的大小,修改以后正常。
问题2:
socket连接成功以后,服务线程主动退出,主服务线程也就是阻塞线程accept()无效,客户端再也连接不上,初始化运行(没有任何客户端连接时)
top -H -p 4715查看线程状态,两个线程正常,4716为服务器监听线程,测试连接客户端,4716线程退出,增加了4731线程退出客户,只有4715线程在,可以肯定线程4716被异常退出了。检查代码发现线程while(1)中多写了一个break,导致线程自己退出了(粗心,不仔细)。
问题3:
void xxx(void)
{
u32 __sum;
__sum +=3;
}
u32 __sum=0;初始化赋初值
图1
图2