1.内存泄漏:申请的堆内存没有释放。
2.内存污染:前面非法操作使用内存(没有报错),后面写着写着就出错。如下代码:
当结构体中只有划线部分代码时,在编译器中编写不会报错,但此时已经造成非法操作内存,下面再给结构体添加一些变量,此时就会报错,不让再定义变量(这种错误特别不好调试)需要注意。
3.对空字符串和非法字符串的判断:
图中画蓝线的部分:应该判断的是指针变量的值,而不是指针指向的内存
4.指针越界:如:str[3] = "abc";
5.指针的叠加会不断改变指针的指向。
如:char *p ="sdfg"; p++; printf("%s\n",p);打印结果为:"dfg";。指针的只想被改变,如果再叠加4次,就打印不出内容了,因为指针此时已经指向了结束符。
6.栈区局部变量的地址不要往外传。如:
char *get_str()
{
char str[] = "abcdedsgads"; //栈区,
printf("[get_str]str = %s\n", str);
return str;
}
7.同一块内存区域被多次释放;如
har *p = NULL;
p = (char *)malloc(50);
strcpy(p, "abcdef");
if (p != NULL)
{
//free()函数的功能只是告诉系统 p 指向的内存可以回收了
// 就是说,p 指向的内存使用权交还给系统
//但是,p的值还是原来的值(野指针),p还是指向原来的内存
free(p);
}
if (p != NULL)
{
free(p);
}