本文章谈论的内容是谈谈我个人在C语言学习中对整型数据在计算机内存中的存储形式的理解。
既然要谈整型,那么我们首先得简单了解一下C语言中基本数据类型有哪些。
注:字符类型严格意义上也归属于整型。
1.整型的定义
整型指没有小数部分的数据,整型可分为整型常量和整型变量,其数值表示在计算机中可分为2进制、8进制、10进制和16进制四种表示形式。如:在32位机器上,10进制整数 11 用二进制表示为:00000000 00000000 00000000 00001011,用八进制表示为:013, 用16进制表示为: 0xb。
2.计算机中有符号整型的表示方法
计算机中整数有三种表示方法,即原码,反码,补码。
三种表示方法均由符号位和数值位组成,其中最高位为符号位,最高位为1表示正数,为0表示负数;除最高位其余的比特位均为数值位。
正数的原码,反码,补码是相同的。例如:10进制整数 13 的原、反、补码分别为:
//原码:00000000 00000000 00000000 000``001101
//反码:00000000 00000000 00000000 000001101
//补码:00000000 00000000 00000000 000001101
负数的原码除最高位为1外,其余数值位用对应的二进制换算规则去表示;反码是在原码符号位不变的基础上,其它位按位取反;补码则是在反码的基础上加1得到的。例如:10进制整数 -6 的原、反、补码分别为:
//原码:10000000 00000000 00000000 00000110
//反码:11111111 11111111 11111111 11111001
//补码:11111111 11111111 11111111 11111010
–>整型在计算机内存中的存储形式为补码。 验证结果如下图:(注:为方便展示,整型在计算机中内存中用16进制表示)
正数13的补码为: 00000000 00000000 00000000 00001101
负数-6的补码为: 11111111 11111111 11111111 11111010
3.整型数据的大小端存储
相信大家已经了解到整型在内存中是以补码的形式存储的,但你们心中是否又产生了另一个疑问:“为什么存储在计算机内存中数据的顺序与实际上是相反的?”
–>这是因为数据在内存中的存储分为大端存储和小端存储。(不同机器的大小端存储由机器本身决定)
–>大端存储:指一个数据的低位字节序的内容放在高地址处,高位字节序存的内容放在低地址处。
–>小端存储:指一个数据的低位字节序内容存放在低地址处,高位字节序的内容存放在高地址处。
例:一个16进制整数 0x0010000d 的大小端存储模式分别如下图所示:
注:计算机将数据在内存中存储的最小单位划分为1个字节。内存地址+1代表数据所占空间大小增加1个字节。
这是我的第一篇个人正式博客,由于本人目前知识储备有限,如有错误,欢迎你的指正,非常感谢你的观看!