在计算机系统中,我们是以字节为单位的,每个地址单元都对应着一个字节,一个字节为8bit,对于位数大于8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节,那么必然存在着一个如果将多个字节安排的问题。因此就导致了大端存储模式和小端存储模式。
Java基础类型字节:byte 1字节,short 2字节, int 4字节, long 8字节, float 4字节, double 8字节, Char 2字节(C语言中是1字节)可以存储一个汉字,boolean(理论上占用1bit,1/8字节,实际处理按1byte处理)JAVA是采用Unicode编码。每一个字节占8位。其中一个字节由8个二进制位组成
但是在C语言中除了8bit的char之外,还有16bit的short型,32bit的long型(要看具体的编译器)。
存储量大于1字节,非char类型,如int,float等,要考虑字节的顺序问题了。
字节序常被分为两类:
1)Big-Endian(大端字节序):是指数据的高字节,保存在内存的低地址中,而数据的低字节,保存在内存的高地址中(网络上一般都是采用大端模式,符合人类正常思维,TCP/IP协议强行约定了使用”大端“作为网络字节序)
2)Little-Endian(小端字节序):是指数据的高字节保存在内存的高地址中,而数据的低字节保存在内存的低地址中(方便计算机处理,iOS默认小端)
- 按位与 &
同为1为1,否则为0
例如:3 & 5
0000 0011
0000 0101
0000 0001 = 1
所以 3 & 5=1
特点:
(1)清零:任何数和0相与,结果为0.
(2)取出指定位的值。取哪一位,就把对应的位定为1。
例如:
拿到了一个16位的数据result = 0000 1010 1010 0110,如何拿到这个数据的低4位呢?
就可以使用按位与,代码如下
2、按位或 |
只要有一个为1就为1
负数按补码的形式参加按位或运算例如:3 | 5
0000 0011