1.内存中存取数据是采用补码形式存储。
符号位:0正1负
正数:原码=反码=补码
负数:反码=原码基础上符号位不变取反 补码=反码基础上+1
例子:假设用short a = -3;
原码:1000 0000 0000 0011
反码:1111 1111 1111 1100
补码:1111 1111 1111 1101
2.以无符号数形式输出有符号数
include <stdio.h>
int main()
{
int a = -0x1;
printf("a=%#x",a);
return 0;
}
结果:a=0xffffffff ,先看内存中存储的a是补码:ffffffff,当我们告诉编译器,我们要以无符号形式(%#x)去输出a,(无符号数没有符号位),编译器会直接将内存中的所有值提取,因为原码=反码=补码。所以,输出的是0xffffffff。
3.以有符号数形式输出无符号数
include <stdio.h>
int main()
{
unsigned short b = 0xffff;
printf("b=%hd",b);
return 0;
}
结果:b=-1,b在内存中的形式是补码:1111 1111 1111 1111(原码反码都相同),但是以有符号数形式输出,编译器会去关注符号位,本身无符号数是没符号位的,编译器这个时候,关注符号位,b为1,即为负数,那么要输出负数,就需要进行转换,得到原码输出->减1取反->1000 0000 0000 0001
`
本文介绍了C语言中内存中数据的补码存储方式,包括正负数的补码表示。当以无符号数形式输出有符号数时,会直接输出内存中的所有值。而以有符号数形式输出无符号数,编译器会考虑符号位,将原本无符号的数值转换为对应的有符号负数形式。
375

被折叠的 条评论
为什么被折叠?



