目录
简略理解计算机为什么要采纳二进制示意信息:
二进制位剖析
那么为什么int就占了4个字节呢?
问:所有的int都是占四个字节吗?
总结
简略理解计算机为什么要采纳二进制示意信息:
因为计算机作为一种电子计算机工具,是由大量的电子器件组成的,在这些电子器件中,电路的通断,电位的高下,用两个数字符号“1”和“0”别离示意容易实现,同时二进制的运算法令也很简略,因而计算机外部通常采纳二进制代码来作为外部存储,传输和解决数据,二进制数据是用0和1两个数码来示意的数,它的基数为2(逢二进一,借一当二)
其实最开始应用的并不是二进制,而是十进制,因为人们有十个手指头,手能够示意十个数字,所以十进制是比拟正当的,0的概念是之后很久才诞生的,所以是0-10而不是0-9。
电子计算机呈现当前,应用电子管来示意十种状态过于简单,所以所有的电子计算机中只有两种根本的状态,开和关。也就是说,电子管的两种状态决定了以电子管为根底的电子计算机采纳二进制来示意数字和数据。罕用的进制还有8进制和16进制,在电脑迷信中,常常会用到16进制,而十进制的应用非常少,这是因为16进制和二进制有人造的分割:4个二进制位能够示意从0到15的数字,这刚好是1个16进制位能够示意的数据,也就是说,将二进制转换成16进制只有每4位进行转换就能够了。
为什么应用二进制咱们理解了,当初就直奔咱们主题
二进制位剖析
首先计算机只意识二进制。而一个字节是8位二进制,只用0和1来示意状态,那么咱们看看一位能示意多少个状态
1 位:0 和 1 也就是2的一次方,最多示意2个状态(要么是0,要么是1)
2 位:00 和 11 也就是2的2次方,最多示意4个状态,也就是(00,01,10,11)
3 位: 000 和 111 也就是2的3次方,最多示意8个状态,也就是(000,001,010,011,100,101,110,111)
……以此类推
8位: 就能够示意2的8次方个状态 = 256个状态
9位:示意2的9次方 = 512个状态
10位:示意2的10次方 = 1024个状态
32位:示意2的32次方 = 4294967296个状态
查看底层源码咱们能够看到
而int如果转成十进制的话,那么他们的范畴[-231~231 -1],也就是“-2147483648 ~ 2147483647”
计算机为了辨别正负数,所以把256个状态一半给了正数,也就是“-128~127”这256个数(因为要正负,所以从8位中拿走认为来示意)
byte 占 1个字节 = 8个比特位 就能够示意2的8次方个数
short占 2个字节 = 16个比特位……
int 占 4 个字节 = 32个比特位
那么为什么int就占了4个字节呢?
在JAVA中一共有八种根本数据类型,它们别离是 byte、short、int、long、float、double、char、boolean
其中byte、short、int、long都是示意整数的,只不过他们的取值范畴不一样
byte 占用1个字节 它的取值范畴为 -128 ~ 127
内存开销:
byte a = 1; // 00000001
short 占用2个字节,它的取值范畴为 -32768 ~ 32767
short a = 1; // 00000000 00000001
int占用4个字节,它的取值范畴为 -2147483648 ~ 2147483647
int a = 1; // 00000000 00000000 00000000 00000001
long占用8个字节,它的取值范畴为 -9223372036854774808 ~ 9223372036854774807
这里就不写了~
问:所有的int都是占四个字节吗?
答复:不肯定是4个字节,他和操作系统有关系,int占多少个字节是由编译器决定的 以前16位零碎中int是2个字节的,而当初32位的零碎,int是4个字节的,其实当初基本上都是64位零碎, 所谓的16位32位64位零碎是由cpu决定的,由机器指令的寻址、寄存器位数决定的 os受cpu的限度,但在32位的cpu下16位的os也能够跑 很多os是向前兼容的,就是使以前的程序也能运行,如果编译器自身是16位时代做的,那么os会提供一个模仿16位的子环境供这个编译器应用 非要转牛角尖的话,int只是语言定义外面的一个关键字,只对compiler可见,complier说它是几位就是几位,和os/cpu都没关系
总结
本片文章就到这里了,心愿可能给你带来帮忙