kkae8643150
狂奔的CD
2016-10-28 03:15
采纳率: 100%
浏览 813
已采纳

一道c语言指针的思考题

int * pn, char * pc, char c = 0x65;
pn = (int * ) & c; //(3)
int n = * pn; //(4)

  • pn = 0x12345678; //(5)

语句(4)的执行结果,是使得n的值变为0x65吗?语句(5)编译会不
会出错?如果不出错,执行后会有什么结果?会不会有问题?

问题1:运行后n的值变成了0xcccccc65,为啥不是0x65;
问题2:语句(5)编译没有出错,执行后最后异常了,Stack around the variable 'c' was corrupted.
为啥?

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

5条回答 默认 最新

  • qq423399099
    小灸舞 2016-10-28 07:32
    已采纳

    问题1:* 0xCCCCCCCC : Used by Microsoft's C++ debugging runtime library to mark uninitialised stack memory
    意思是VS下未初始化的栈变量内存会被初始化成0xcccccccc
    而你的char c = 0x65; 只占一个字节,你可以打印下pn,pc,c的地址,c分配到的地址可能在pn,pc前
    问题2:
    你pn = 0x12345678; 会越界写入3个字节:
    DEBUG模式下可能会破坏调试信息(变量的周围有一些空间是放调试信息的),导致程序结束析构出错,出现Stack around the variable 'c' was corrupted.

    点赞 评论
  • qq_34941745
    柴星星 2016-10-28 04:04

    c变量存不下’0x65‘4个字符啊

    点赞 评论
  • qq_34770510
    曹大仙呀 2016-10-28 08:26
    1      char c ,char类型只占一个字节,0x65是16进制数,占2个字节,是不下0x65的
    
    2      pn = 0x12345678已越界,越界肯定会报错,因为系统有错误机制,debug会打印出越界对应的信息
    
    3      这类问题最好自己调试一下,理解更加深刻,掌握解决问题的方法最重要
    
    点赞 评论
  • github_36186488
    Findway_ 2016-10-28 13:48

    char c = 0x65 65是16進制數 6占四位 5占四位 所以一共占一个字节,并不是上面说的不能存下
    n 变成 0xcccccc65 因为int型占四个字节 一共会读取以c的地址开头的四个字节, 第一个字节的值为65
    最后一个运行错误 是因为你给出的指针地址 超出了 内存中栈段的范围

    点赞 评论
  • zhusaiqi
    zzxuan3443 2016-10-29 02:37

    楼上说的对,读取的内存比c占得内存大,所以低位是存储进去的65,而高位的c是随机的,也就是和结果会是0X******65。
    至于说超出栈内存,我只知道栈空间是从0xbfffffff向下增长,到哪就不知道了
    图片说明
    在其他问题下面看到的回答(这不侵权吧,见谅)

    点赞 评论

相关推荐