使用了未初始化的内存a_C语言必学,您不得不看的,通用内存/指针相关错误

取消引用未知的内存位置:C程序员大多使用scanf()函数来获取输入,但是有时一个小错误可能会带来错误,甚至使整个程序崩溃。
scanf()的语法为scanf(“%d”,&a);。。有可能错过与和写入&A作为所以现在的scanf(“%d”,一); 正在取消引用到未知位置。
现在,该程序可能会异常终止,或者可能对应于有效位置(与当前程序无关,但与某些其他程序无关),并且可能被覆盖,这可能在以后导致未知效果。

069f3cf73aa730004490a1b86a47b100.png

1b7398a6db13c965e9689531d7bc9cb3.png

读取未初始化的内存。在C语言中,初学者通常使用malloc()提供运行时内存,但是使用malloc()时,不会初始化内存块,因此可以访问。

3337eb35fc685af58bdcdc67cb07ce7c.png

一种解决方案是使用calloc()代替,它将块初始化为0。

缓冲区溢出:这是在C中发生的一个非常常见的错误,由于在C本身中存在错误的函数(即用于将字符串作为输入的gets()函数)而变得更加常见。它不检查提供的用于在程序中存储字符串的内存,因此,如果用户输入更大的字符串,则get()在字符串之后覆盖内存位置并导致get()并导致溢出。

2d4254e98e0c90cae8252db31a13287b.png

该代码遭受缓冲区溢出的困扰,因为gets()不执行任何数组绑定测试。gets()继续阅读,直到看到换行符为止。为避免缓冲区溢出,应使用fgets()代替gets(),因为fgets()确保读取的字符数不能超过MAX_LIMIT个。

8fadba18a0c2e824c77072219a502630.png

内存泄漏当未使用的堆内存未分配时,由于主内存最终被填满,而可用内存变少,就会出现这种情况。

edc955af3de841a8c96113dae78e9163.png

如果不再使用内存,则应在malloc()之后使用free()。

d41eca1f0daea0625929d27931082e7f.png

由于优先级而导致的错误对运算符及其优先级的了解较少,可能会产生错误,尤其是对于像

a8e1a50d1b48e0974e679176d26fc0d5.png

*的优先级(取消引用/间接运算符不是乘法)和后缀++并不相同,但是前缀++和*具有相同的前缀,因此,首先p的值将增加并指向错误的内存区域,然后取消引用并将覆盖该位置或程序可能会终止。

发送不存在的变量的地址局部变量的返回地址会导致问题,

90f530becde66cd6d0a63b92420495ca.png

当函数fun()称为变量a时,将创建一个,但是一旦函数返回,它将被销毁。由于返回了函数,其地址p将指向堆栈区域中的存储区,如果调用了另一个函数,则指针p的更改可能会导致错误。

指针算术指针算术可能会令人困惑,让我们举一个例子,假设整数为4字节。

908c824812dfe9a03ba5ac01e3547790.png

尽管由于整数为4个字节并且p在起始位置看起来是正确的,所以将其加4将导致p指向数组n中的下一个整数,但是指针算术根据其数据类型的大小工作,因此将1加到指针n整数,然后将sizeof(int)添加到其中,这同样适用于指向任何其他数据类型的指针。

43f74083776aeb8fa7da4aa13ce5cb9f.png

将数组作为参数传递当我们将数组传递给函数时,它始终被视为函数中的指针。这就是为什么我们永远不要在数组参数上使用sizeof的原因。我们应该总是将size作为第二个参数

dc26126c82caf0f7dc034e394c340e45.png

下面是更正的代码

f5f6efa25842c2bbab4940fd5cc7590a.png

学习更多,领取免费学习资料及教程,请查看下方图片:

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值