我把R这个ASCII码转变成16进制的编码之后为 52 ,但是现在我想要把这个52
转换成0x52 并且,把这个0x52 放到byte[] 数组中,
最终形成这种样式 byte[] b = { 0x52 ,0x63}这种样式。求大神给出方案。
我看过一个博客有如下方法,但是他得出的答案根本就跟他注释描述的
完全不一样,不知道为什么还好多人转载,也不知道谁是最初的作者,我就是想要
达到他注释里面描述的那种一样
/**
* 将两个ASCII字符合成一个字节; 如:"EF"–> 0xEF
*
* @param src0
* byte
* @param src1
* byte
* @return byte
*/
public static byte uniteBytes(byte src0, byte src1) {
byte _b0 = Byte.decode("0x" + new String(new byte[] {src0})).byteValue();
_b0 = (byte) (_b0 << 4);
byte _b1 = Byte.decode("0x" + new String(new byte[] { src1 })).byteValue();
byte ret = (byte) (_b0 ^ _b1);
return ret;
}
/**
* 将指定字符串src,以每两个字符分割转换为16进制形式 如:"2B44EFD9" –> byte[]{0x2B, 0×44, 0xEF,
* 0xD9}
*
* @param src
* String
* @return byte[]
*/
public static byte[] HexString2Bytes(String src) {
if (null == src || 0 == src.length()) {
return null;
}
byte[] ret = new byte[src.length() / 2];
byte[] tmp = src.getBytes();
for (int i = 0; i < (tmp.length / 2); i++) {
ret[i] = uniteBytes(tmp[i * 2], tmp[i * 2 + 1]);
}
return ret;
}
其实就一个需求:
将两个ASCII字符合成一个字节; 如:"EF"–> 0xEF
不知道你是 0x5 0x2合并成0x52 还是 '5'和'2'合并成0x52
前者,0x5*16+0x2
后者 (byte)Integer.valueOf(("5" + "2"), 16);
将两个ASCII字符合成一个字节; 如:"EF"–> 0xEF
就是这个需求
看你的意思是把数字转换成字符形式,前面再加上0X,直接强制转换试试
public static void main(String[] args) {
// 两字节的字符串s以16进制的权值转换成byte类型a
String s="2B"; //原字符串
System.out.println(s); //输出字符s
byte a=(byte)Integer.parseInt(s, 16); //调用函数:字符串s以16进制的权值转换成byte类型a
System.out.println(a); //输出a的十进制表示
System.out.println(Integer.toHexString(a)); //输出a的十六进制表示
}
//输出结果:
2B
43
2b
使用string.format()就行
char[] r = {'R','e'};
System.Text.ASCIIEncoding asciiEncoding = new System.Text.ASCIIEncoding();
byte[] ir = asciiEncoding.GetBytes(r);
其实这个问题,我一直在纠结的是,接口需要的是byte[] 数组。而接口文档给出的是 byte[] b = { 0x52 , 0x43} 这种样式,所以我理所当然的认为,
传递进去的入参也得是byte[] 类型的,且初始化的样式得是 { 0x52 ,0x84} 这种的,但是实际上只需要保持传递进去的是 byte 数组 就行了,而 0x52
只是System.out 输出的10进制的表示数