这是今天的小课堂题目:
#include<stdio.h>
int main()
{
int a = -1;
unsigned int n_a = a;
printf("十进制 a = %d \n",a);
printf("十进制 n_a = %u \n",n_a);
printf("十六进制 a = %x \n",a);
printf("十六进制 n_a = %x \n",n_a);
return 0;
}
可以先看看结果: 直接讲分析: 在计算机世界里,数据都是以二进制的形式存储,然后当c语言执行赋值操作的时候,实际上是把二进制的数据从一个地址拷贝到另外一个地址。
而在c语言中也有很多的数据类型,关于数据类型的讲解,博主之前写过一篇自己关于c语言数据结构的理解 浅谈数据类型 可以浅看一下。
我们知道
int 型(integer)
一般4 byte = 32 bits(4 字节 = 32 比特) 有符号signed范围:-2^31 ~ 2^31 即:-2147483648 ~ 2147483648
无符号unsigned范围:0 ~ 2^32-1 即:0 ~ 4294967295
但是实际上不管是有符号还是无符号的int型储存变量都是用4个字节,也就是32位(64位操作系统) 只不过我们读取这些二进制值的时候按照不一样的规律而已 无符号的int能表示的正数更大,那是因为无符号的int的32位都能表示正数,而有符号的int因为需要表示负数,所以理所当然的把最高位当成符号位
可以看到这里的-1是一个有符号的int型数据,在空间中储存的值实际上是 1111 1111 1111 1111 1111 1111 1111 1111 这个数据是怎么来的呢 其实就是1取反(还记得取反吗,昨天刚讲过,是对二进制数全部反过来得操作),然后+1 int a = 1的二进制储存 0000 0000 0000 0000 0000 0000 0000 0001 取反之后就是 1111 1111 1111 1111 1111 1111 1111 1110 最后加一就变成了 1111 1111 1111 1111 1111 1111 1111 1111 这就是一个有符号int型数据的二进制存储方式
今天的题目也表示虽然两个数据的二进制形式是一样的 但是按照不同的方法来读取,会有不同的值 你学会了吗
|