沿途有余弦 2017-06-03 02:31 采纳率: 75%
浏览 825
已采纳

这个偶然看到的不明白,关于两个类型的指针转化问题也是第一次接触

首先,数组a中两个int变量应该是八个字节,看图应该不是我想的(0261,0000)(这个纯属瞎猜哈),5和1是怎么回事?还有转换,两个类型不同的在转换时内存占用大小不一样,怎么处理的?图片

  • 写回答

1条回答 默认 最新

  • 一个纸杯 2017-06-03 03:43
    关注

    这个问题首先你要了解计算机的内存机制,计算机内存一般是按字节存储的(至少我们现在用的pc机都是这样),我们分析的时候经常数字转化为16进制进行分析,因为一位16进制正好是4bit,两位16进制就是一字节,261转化为16进制之后是105,如下:
    图片说明
    然后它在内存中的存储如果按照大端存储,就是下图这样的,我们用的pc机大多是按照大端存储的,就是低字节存在内存的低地址,小端存储相反,不清楚的话自己百度一下:
    图片说明
    看到这应该很明白了吧。

    cout<<*(int*)p++<<endl;
    解释:p指针转化为int型指针,并取内容,也就是说,从p指针指向的地方开始,取int长度个字节,也就是4字节,所以取出来的是00,00,01,05,也就是261的16进制,输出时按照10进制输出的,所以是261
    cout<<*(int*)p<<endl;
    和上一步一样,只是上一步p已经后置自增,所以现在p指向01,所以取出来是00,00,00,01,也就是1的16进制表示(与其十进制表示一样),所以输出1。
    cout<<(int)*p<<endl;
    这一步是将p指向的内容取出来,记住p是一个char型指针,一直都没有改变,所以只取一个字节,也就是01,(int)部分是将它扩展为4字节,这采用的应该是符号扩展(这是数字逻辑或计算机组成原理的知识,不清楚请自行百度),因为是正数,所以前面添0就行,扩展之后是00,00,00,01,和上一步一样,输出1。
    cout<<(int)*(char*)pi<<endl;
    这一步看着很绕,其实都是纸老虎,首先pi是一个int型指针,指向的是05,先将它转外为char型指针并取其内容,也就是只取一个字节内容,就是05,然后将其转化为int型的值,也是符号扩展,前面加0,扩展之后是00,00,00,05,再将这16进制转化为十进制,就是5。

    需要注意的是,指针操作,类型转换操作,应该考虑操作的优先级,这四个转化中,都是自后向前的。

    祝你学习愉快,纯手打,求悬赏。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?