java中float与byte[]的互转

本文介绍三种将浮点数(float)转换为字节序列(byte[])的方法,并提供了具体的Java实现代码。方法包括使用ByteBuffer、通过int中间类型转换及自定义数组翻转等技巧。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

起因:想把一个float[]转换成内存数据,查了一下,下面两个方法可以将float转成byte[]。 

方法一 

	import java.nio.ByteBuffer;
	import java.util.ArrayList;

	float buffer = 0f;
	ByteBuffer bbuf = ByteBuffer.allocate(4);
	bbuf.putFloat(buffer);
	byte[] bBuffer = bbuf.array();
	bBuffer=this.dataValueRollback(bBuffer);

        //数值反传
	private byte[] dataValueRollback(byte[] data) {
		ArrayList<Byte> al = new ArrayList<Byte>();
		for (int i = data.length - 1; i >= 0; i--) {
			al.add(data[i]);
		}

		byte[] buffer = new byte[al.size()];
		for (int i = 0; i <= buffer.length - 1; i++) {
			buffer[i] = al.get(i);
		}
		return buffer;
	}

方法二 
先用 Float.floatToIntBits(f)转换成int 
再通过如下方法转成byte [] 

	/**
	 * 将int类型的数据转换为byte数组 原理:将int数据中的四个byte取出,分别存储
	 * 
	 * @param n  int数据
	 * @return 生成的byte数组
	 */
	public static byte[] intToBytes2(int n) {
		byte[] b = new byte[4];
		for (int i = 0; i < 4; i++) {
			b[i] = (byte) (n >> (24 - i * 8));
		}
		return b;
	}

	/**
	 * 将byte数组转换为int数据
	 * 
	 * @param b 字节数组
	 * @return 生成的int数据
	 */
	public static int byteToInt2(byte[] b) {
		return (((int) b[0]) << 24) + (((int) b[1]) << 16)
				+ (((int) b[2]) << 8) + b[3];
	}

方法三(这个是我在用的): 

	/**
	 * 浮点转换为字节
	 * 
	 * @param f
	 * @return
	 */
	public static byte[] float2byte(float f) {
		
		// 把float转换为byte[]
		int fbit = Float.floatToIntBits(f);
		
		byte[] b = new byte[4];  
	    for (int i = 0; i < 4; i++) {  
	        b[i] = (byte) (fbit >> (24 - i * 8));  
	    } 
	    
	    // 翻转数组
		int len = b.length;
		// 建立一个与源数组元素类型相同的数组
		byte[] dest = new byte[len];
		// 为了防止修改源数组,将源数组拷贝一份副本
		System.arraycopy(b, 0, dest, 0, len);
		byte temp;
		// 将顺位第i个与倒数第i个交换
		for (int i = 0; i < len / 2; ++i) {
			temp = dest[i];
			dest[i] = dest[len - i - 1];
			dest[len - i - 1] = temp;
		}
	    
	    return dest;
	    
	}
	
	/**
	 * 字节转换为浮点
	 * 
	 * @param b 字节(至少4个字节)
	 * @param index 开始位置
	 * @return
	 */
	public static float byte2float(byte[] b, int index) {  
	    int l;                                           
	    l = b[index + 0];                                
	    l &= 0xff;                                       
	    l |= ((long) b[index + 1] << 8);                 
	    l &= 0xffff;                                     
	    l |= ((long) b[index + 2] << 16);                
	    l &= 0xffffff;                                   
	    l |= ((long) b[index + 3] << 24);                
	    return Float.intBitsToFloat(l);                  
	}


### 将Float类型换为Byte数组 在Java中,`float` 类型占用4个字节的空间。如果目标是将其压缩成仅含两个元素的 `byte` 数组,则会丢失精度或部分数据,因为这实际上减少了用于表示原数值的信息量。然而,在某些特定应用场景下,比如通信协议规定或是为了节省存储空间,这种需求确实存在。 对于将标准四字节浮点数缩减至二字节数组的情况,通常不是简单的截断处理而是采用某种形式的数据映射或者是近似算法来完成此过程。但是,直接从 `float` 到仅有两位有效信息承载能力的 `byte[2]` 的变并不常见也不推荐,除非是在非常特殊的情况下,并且开发者清楚了解这样做带来的后果。 若仍然希望实现这样的功能,可以通过自定义编码方案来进行简化: ```java public class FloatToByteArray { public static byte[] floatToTwoBytes(float value) { // 假设只保留整数部分并化为short(2 bytes), 这里简单举例, 实际应用需更复杂的逻辑. short sValue = (short)value; byte[] result = new byte[2]; for(int i=0;i<2;i++){ result[i]=(byte)((sValue>>(8*i))&0xff); } return result; } public static void main(String args[]) { float originalValue = 123.45f; byte[] twoBytesArray = floatToTwoBytes(originalValue); System.out.println("Original Value: " + originalValue); System.out.print("Converted to Two Bytes Array: "); for(byte b : twoBytesArray){ System.out.printf("%02X ",b); } } } ``` 上述代码展示了如何将一个 `float` 变量的内容简化为只有其整数部分,并进一步拆分为两个字节的形式保存在一个长度为2的 `byte` 数组内[^2]。请注意这种方法会导致大量原始数据信息丧失,特别是当涉及到小数部分;因此建议谨慎评估具体业务场景后再决定是否采取这种方式。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值