关于数据在内存的存放,及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,正确。 你先用sizeof(short)看一下你的机器上short是几个字节的数据 sidfate 发表于 2014-4-28 21:43 static/image/common/back.gif
你先用sizeof(short)看一下你的机器上short是几个字节的数据
是2byte的。 本帖最后由 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 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
学习了,,,,, sidfate 发表于 2014-4-28 21:58 static/image/common/back.gif
经过调试后发现:
q = (char*)p;
:handshake 不错,谢谢。 oggplay 发表于 2014-4-29 10:38 static/image/common/back.gif
16位系统补码0xffff=-1,32位系统0xffffffff=-1,64位系统0xffffffffffffffff=-1,这叫补码的扩展。另外,指 ...
多谢指导:handshake
页:
[1]