(1)memset对没有malloc的字符数组,会发生crash
(2)非成员函数B声明,要在使用B的函数A前面,不然会报该函数A找不到函数B的错误。即非成员函数要在调用他的函数前面声明。
(3)malloc函数要对其返回值进行判断,返回NULL则是申请内存不成功,应该不再处理程序
(4)如果是memset,memcpy等方法错误,那么crash的backtrace在使用addr2line怼出来的地址是很奇怪的,可能是方法的结束括号。
另外backtrace的栈顶一行最后会显示该string.h出错。
(5)如果两个lib对应头文件没有对齐,那么crash的backtrace在使用addr2line怼出来的地址是很奇怪的,也是方法的结束括号,另外注释掉头文件增加的函数之后,则不会再crash. 另外backtrace的栈顶一行最后会显示该函数
(6)qsort(数组名,数组元素个数,单个数组元素所占字节数,compare函数指针).如果数组元素个数填错,大于实际的大小,会crash于memcpy函数
(6)memcpy(拷贝去向数组地址,拷贝来源数组地址,拷贝的元素个数)
待续..

本文探讨了C语言编程中常见的几个陷阱,包括使用memset和memcpy时的潜在风险、内存分配失败处理不当的问题、函数声明顺序的重要性、qsort函数使用不当导致的崩溃等。这些常见错误可能导致程序崩溃或行为异常。
4万+

被折叠的 条评论
为什么被折叠?



