一道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个回答

问题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.

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

1      char c ,char类型只占一个字节,0x65是16进制数,占2个字节,是不下0x65的

2      pn = 0x12345678已越界,越界肯定会报错,因为系统有错误机制,debug会打印出越界对应的信息

3      这类问题最好自己调试一下,理解更加深刻,掌握解决问题的方法最重要

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

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

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问