首先 只有String才与编码有关;
byte与其他类型转换时,要注意大端点还是小端点,
编码: Ascii Unicode gbk utf-8等等
byte 占 8位 可由两个16进制数(0xff)组成,一个16进制占4位,也可由8位二进制数组成等等,与编码没关系,但可用2进制表示,也可由其他进制表示。
“0xff”这样的16进制字符串转换成16进制byte
String[] s="0X0C 0X03 0X00 0X04 0X00 0X02 0X84 0XD7".replace("X", "x").split(" "); byte[] b=new byte[s.length]; for(int i=0;i<s.length;i++){ b[i]=(byte)Integer.parseInt(s[i].substring(2),16); } System.out.println(Arrays.toString(b));
把byte[n]转换成String;
new String(byte[n],0,length,"gbk");
float占 4字节 ,float与byte类型转换
都是通过移位来实现的
4byte转换成float
左移位
/**
* 字节转换为浮点
*
* @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转换成4byte
右移位
/*** 浮点转换为字节
*
* @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;
}