[c语言]小课堂 day5

这是今天的小课堂题目:

#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的二进制
可以看到这里的-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型数据的二进制存储方式

今天的题目也表示虽然两个数据的二进制形式是一样的
但是按照不同的方法来读取,会有不同的值
你学会了吗

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

某新手

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值