C语言异常代码C0000005的解决办法是:不对地址为NULL的存储空间赋值

指针变量可以初始化为空地址,但是,只有当指针已经指向了具体的地址空间,然后才能对该空间赋值。

定义指针变量temp

int * temp=NULL;
注意:temp指针变量,如果不赋初值,其值是不可预料的,所以建议定义指针变量时,初始化为NULL。
注意:大写的NULL,表示常量。不能改成小写。如果改成小写,就会提示error C2065: “null”: 未声明的标识符。

出错的程序示例

在这里插入图片描述
运行结果提示如下图:
在这里插入图片描述

分析错误

第5行代码 *temp=a; 错误。
因为,temp指针的值是NULL,表示temp指向地址为空(NULL)的存储空间,不能向地址为空的存储空间赋值。所以程序错误。
更正方法:
第5行代码改成 temp=&a; 即,把a的地址赋给指针变量temp。

正确程序示例

在这里插入图片描述

总结在这里插入图片描述

### C语言中调用 `free` 后指针的状态 在C语言中,当调用 `free` 函数释放由动态分配函数(如 `malloc`, `calloc`, 或 `realloc`)分配的内存时,该操作仅释放指针所指向的内存区域,并不会自动将指针本身设置为 `NULL`[^1]。这意味着,在 `free` 调用之后,虽然指针仍然保存着原来的地址值,但它不再指向有效的内存块。 这种情况下,如果未显式地将指针设为 `NULL`,那么这个指针就变成了所谓的 **野指针**[^2]。所谓野指针是指那些曾经指向一块已分配的内存但在其对应的内存被释放后仍保留原地址值的指针。由于这些指针并不真正指向任何合法的对象或变量,因此再次尝试通过此指针访问或修改数据可能会引发不可预测的行为甚至程序崩溃。 为了避免上述风险并提高代码的安全性和稳定性,在每次完成对某段动态存储空间的操作后应立即将相应的指针赋值为 `NULL`: ```c char *p = (char *) malloc(100); strcpy(p, "hello"); free(p); // 释放 p 指向的内存 p = NULL; // 将 p 设置为 NULL 防止形成野指针 ``` 此外值得注意的是,无论对于 `free` 还是 `delete` 来说,只要初始状态下传入的是一个空(`NULL`)指针,则不论对其进行多少次释放都不会出现问题;这是因为标准库实现里包含了针对这种情况下的保护措施——一旦发现待释放对象是一个空指针便会立即退出而不做进一步动作[^3]。 然而需要注意一点就是尽管多次释放同一个已经被置零后的null pointer不会有影响,但对于非空且已被先前解除关联过的常规pointer而言重复调用free将会造成严重的运行期错误包括但不限于程序异常终止等情况发生[^5]。 综上所述,为了防止潜在的风险和隐患,在实际开发过程中应当养成良好的习惯即每当你决定丢弃某个之前经new/malloc获得资源的时候除了必要的清理工作之外还应该记得及时更新相关联的pointers使其处于安全状态之中比如重定向至新的目标或者是简单粗暴地赋予他们特殊的标志位例如这里讨论到的例子那样直接设定成Null即可达到目的. ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值