《C和指针》(6)指针

问题

  1. 如果一个值的类型无法简单地通过观察它的位模式来判断,那么机器是如何知道应该怎样对这个值进行操纵的?

    :机器无法作出判断。编译器根据值的声明类型创建适当的指令,机器只是盲目地执行这些
    指令而已。

  2. C为什么没有一种方法来声明字面值指针常量呢?

    :它们很少被使用,因为你无法提前判断编译器将把变量放在哪里。

  3. .假定一个整数的值是244。为什么机器不会把这个值解释为一个内存地址呢?

    :该值是一个整数,因此编译器不会生成取消引用它的指令

  4. 在有些机器上,编译器在内存位置零存储0这个值。对NULL指针进行解引用操作将访问这个位置。这种方法会产生什么后果?

    :这是很危险的。首先,解引用一个NULL指针的结果因编译器而异,所以程序不应该这样做。允许程序在这样的访问之后还能继续运行是很不幸的,因为这时程序很可能并没有正确运行。

  5. 表达式(a)和(b)的求值过程有没有区别?如果有的话,区别在哪里?假定变量offset的值为3。

    · 在这里插入图片描述

    :即使偏移量与下一个表达式中的文字值相同,计算第一个表达式也会更耗时,因为必须在运行时进行将偏移量缩放为整数大小的乘法运算。这是因为变量可能包含任何值,编译器无法提前知道实际值。另一方面,可以在编译时将文字3乘以整数,然后在运行时将相乘的结果简单地添加到p。换句话说,第二个表达式可以通过简单地在p上加12来实现(在具有四字节整数的机器上);不需要运行时乘法。

  6. .下面的代码段有没有问题?如果有的话,问题在哪里?
    在这里插入图片描述
    :有两个错误。对增值后的指针进行解引用时,数组的第1个元素并没有被清零。另外,指针在越过数组的右边界以后仍然进行解引用,它将把其他某个内存地址的内容清零。
    注意pi在数组之后立即声明。如果编译器恰好把它放在紧跟数组后面的内存位置,结果将是灾难性的。当指针移到数组后面的那个内存位置时,那个最后被清零的内存内置就是保存指针的位置。这个指针(现在变成了零)因此仍然小于&array[ARRAY-SIZE],所以循加将继续执行。指针在它被解引用之前增值,所以下一个被破坏的值就是存储于内存位置4的变量(假定整数的长度为4个字节)。如果硬件并没有捕捉到这个错误并终止程序,这个循环将快乐地继续下去,指针在内存中欢快地前行,破坏它遇见的所有值0当它再一次到达这个数组的位置时,就会重复上面这个过程,从而导致一个微妙的无限循环。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Elec Liu

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值