首先 只有string才与编码有关;
byte与其他类型转换时,要注意大端点还是小端点,
编码: ascii
unicode gbk utf-8等等
byte 占 8位 可由两个16进制数(0xff)组成,一个16进制占4位,也可由8位二进制数组成等等,与编码没关系,但可用2进制表示,也可由其他进制表示。
“0xff”这样的16进制字符串转换成16进制byte
把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));
}
// 翻转数组
len = b.length;
建立一个与源数组元素类型相同的数组
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;