大端小端存储二进制与字节的转换

本文详细介绍了大端和小端字节序的概念,并通过实例展示了如何在内存中存储无符号整数。同时,提供了将字节转换为二进制字符串和字节数组的方法,以及short、int、long与字节之间的转换操作,对于理解二进制数据处理和存储至关重要。
摘要由CSDN通过智能技术生成

大端小端二进制与字节的转换

单位换算

位:“位(bit)”是电子计算机中最小的数据单位。每一位的状态只能是0或1。

字节:8个二进制位构成1个“字节(Byte)”,它是存储空间的基本计量单位。1个字节可以储存1个英文字母或者半个汉字,换句话说,1个汉字占据2个字节的存储空间。

字:“字”由若干个字节构成,字的位数叫做字长,不同档次的机器有不同的字长。例如一台8位机,它的1个字就等于1个字节,字长为8位。如果是一台16位机,那么,它的1个字就由2个字节构成,字长为16位。字是计算机进行数据处理和运算的单位。

KB:在一般的计量单位中,通常K表示1000。

8bit(位)=1Byte(字节)

1024Byte(字节)=1KB

1024KB=1MB

1024MB=1GB

换算率约等于1000(1024),从大到小顺序为T、GB、MB(兆Zhao)、KB、B再小就是位了

在这里插入图片描述

1.什么是大端与小端?

  • 大端模式,是指数据的高字节保存在内存的低地址中,而数据的低字节保存在内存的高地址中,这样的存储模式有点儿类似于把数据当作字符串顺序处理:地址由小向大增加,而数据从高位往低位放;这和我们的阅读习惯一致。

  • 小端模式,是指数据的高字节保存在内存的高地址中,而数据的低字节保存在内存的低地址中,这种存储模式将地址的高低和数据位权有效地结合起来,高地址部分权值高,低地址部分权值低。

下面以unsigned int value = 0x12345678为例,分别看看在两种字节序下其存储情况,我们可以用unsigned char buf[4]来表示value

Big-Endian: 低地址存放高位,如下:

低地址
buf[0] (0x12) -- 高位字节
buf[1] (0x34)
buf[2] (0x56)
buf[3] (0x78) -- 低位字节
高地址

Little-Endian: 低地址存放低位,如下:

低地址
buf[0] (0x78) -- 低位字节
buf[1] (0x56)
buf[2] (0x34)
buf[3] (0x12) -- 高位字节
高地址
内存地址小端模式存放内容大端模式存放内容
0x40000x780x12
0x40010x560x34
0x40020x340x56
0x40030x120x78

在这里插入图片描述

2. byte 转二进制字符串

这里以 16进制 0x35 为例,进行二进制字符串转换:(0x35 的二进制为 0011 0101)

public String byteToBinary(byte b){
	return ""+(b>>7&0x1)+(b>>6&0x1)
			 +(b>>5&0x1)+(b>>4&0x1)
			 +(b>>3&0x1)+(b>>2&0x1)
			 +(b>>1&0x1)+(b>>0&0x1)
}
00110101

3. byte 转二进制字节数组

public byte[] toByteArray(byte b){
	byte[] arr=new byte[8];
	int len=arr.length;
	for(int i=0;i<len;i++){
		arr[i]=(byte)((b>>(len-1-i))&0x1);
	}
	return arr;
}
[0, 0, 1, 1, 0, 1, 0, 1]

以下转换例子都是以“小端存储”方式编码的

4. short与字节转换

short 占2byte

  • to byte[]
public byte[] shortTobyte(short n){
    byte[] arr=new byte[2];
    arr[0]= (byte) (n&0xff);
    arr[1]= (byte) ((n&0xff00)>>8);
    return arr;
}	
  • byte to short
public short byteToShort(byte[] arr){
    short n=(short)(arr[0]&0xff)
    |(short)((arr[1]<<8)&0xff00);
    return n;

}

5. int 与字节转换

int 占用4byte
  • to byte[]

    public byte[] intToByte(int n){
    	byte[] arr=new byte[4];
    	arr[0]=(byte)(n&0xff);
    	arr[1]=(byte)((n>>8)&0xff);
    	arr[2]=(byte)((n>>16)&0xff);
    	arr[3]=(byte)((n>>24)&0xff);
    	return arr;
    }
    
    
  • byte to int

public int byteToInt(byte[] arr){
    int n=arr[0]&0xff
        |(arr[1]<<8)0xff
        |(arr[2]<<16)0xff
        |(arr[3]<<24)0xff;
    return n;
}
  1. long 与字节转换
    long 占用8byte
  • to byte[]
	public byte[] longToByte(int n){
		byte[] arr=new byte[8];
		arr[0]=(byte)(n&0xff);
		arr[1]=(byte)((n>>8)&0xff);
		arr[2]=(byte)((n>>16)&0xff);
		arr[3]=(byte)((n>>24)&0xff)
		arr[4]=(byte)((n>>32)&0xff)
		arr[5]=(byte)((n>>40)&0xff)
		arr[6]=(byte)((n>>48)&0xff)
		arr[7]=(byte)((n>>56)&0xff);
		return arr;
	}
	
  • byte to int
	public int byteToLong(byte[] arr){
		int n=arr[0]&0xff
			|(arr[1]<<8)0xff
			|(arr[2]<<16)0xff
			|(arr[3]<<24)0xff
			|(arr[4]<<32)0xff
			|(arr[5]<<40)0xff
			|(arr[6]<<48)0xff
			|(arr[7]<<56)0xff;
		return n;
	}
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值