C 指针的易错点

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.同一块内存区域被多次释放;如

char *p = NULL;

p = (char *)malloc(50);
strcpy(p, "abcdef");

if (p != NULL)
{
	//free()函数的功能只是告诉系统 p 指向的内存可以回收了
	// 就是说,p 指向的内存使用权交还给系统
	//但是,p的值还是原来的值(野指针),p还是指向原来的内存
	free(p);
}

if (p != NULL)
{
	free(p);
}

  

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值