Prophet 发表于 2014-4-28 21:39:27

关于数据在内存的存放,及printf函数遇到的问题。《好人一生平安》

#include<stdio.h>
int main()
{
       short i = 0x00ff;
       short *p = &i;
       char *q ;
       q = (char*)p;
       printf("%x\n",*q);
       return 0;

}
如果系统是低端的上述printf输出不是应该为ff么。为什么是ffffffff,这个东西。十进制输出的时候是-1,正确。

sidfate 发表于 2014-4-28 21:43:19

你先用sizeof(short)看一下你的机器上short是几个字节的数据

Prophet 发表于 2014-4-28 21:44:36

sidfate 发表于 2014-4-28 21:43 static/image/common/back.gif
你先用sizeof(short)看一下你的机器上short是几个字节的数据

是2byte的。

sidfate 发表于 2014-4-28 21:58:15

本帖最后由 sidfate 于 2014-4-28 22:04 编辑

Prophet 发表于 2014-4-28 21:44 static/image/common/back.gif
是2byte的。
经过调试后发现:

q = (char*)p;

执行该语句时 , 系统将p的 FF视为字符的ASCII,也就是是 q 指向了 '-1'(ÿ   Ascii为255的字符) 的单个字符,所以最后输出时将 '-1' 转化为16进制输出 'ffffffff'(十六进制 -1)

oggplay 发表于 2014-4-29 10:38:34

本帖最后由 oggplay 于 2014-4-29 12:39 编辑

16位系统补码0xffff=-1,32位系统0xffffffff=-1,64位系统0xffffffffffffffff=-1,这叫补码的扩展。另外,指针跟系统有关,与int char 变量类型无关。比如char* int*它们只是告诉编译器应该取内存中几个字节的问题,取1个字节就是char ,2个字节就是short或者int,取4个字节就是int或者long类型。例子:
int val=0x12345678;
unsigned char* byte=(unsigned char*) &val;//注意此写法 你的表达式 q = (char*)p应该写为 char* q=(char*) &i
unsigned char p= *byte;
这样一个int 型变量的头一个字节(对于小端法机器来说是0x78)就赋值给了unsigned char类型的变量p。但是val和p的内存地址你是转换不了的,因为操作系统已经给你定义了。

更多的可以看我的帖子2楼的例子http://bbs.fishc.com/thread-45454-1-1.html






枫界易城 发表于 2014-4-29 10:54:17

学习了,,,,,

Prophet 发表于 2014-5-4 22:20:00

sidfate 发表于 2014-4-28 21:58 static/image/common/back.gif
经过调试后发现:

q = (char*)p;


:handshake   不错,谢谢。

Prophet 发表于 2014-5-4 22:21:06

oggplay 发表于 2014-4-29 10:38 static/image/common/back.gif
16位系统补码0xffff=-1,32位系统0xffffffff=-1,64位系统0xffffffffffffffff=-1,这叫补码的扩展。另外,指 ...

多谢指导:handshake
页: [1]
查看完整版本: 关于数据在内存的存放,及printf函数遇到的问题。《好人一生平安》