• [c语言]小课堂 day5


    这是今天的小课堂题目:

    #include
    
    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型数据的二进制存储方式

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

  • 相关阅读:
    proteus 器件名称被软件篡改bug的解决方案
    PostgreSQL-基本结构
    抓包工具fiddler的基础知识
    Windows中通过bat脚本修改系统默认日期与时间
    Go 操作 ElasticSearch 实战
    你准备好启动推荐计划了吗?
    【XSS跨站脚本】DOM型XSS
    论文解读(SUGRL)《Simple Unsupervised Graph Representation Learning》
    SpringBoot中使用(@NotEmpty、@NotBlank、@NotNull)注解校验实体类参数
    微服务实战系列之Nacos
  • 原文地址:https://blog.csdn.net/qq_28406527/article/details/127024477