请注意,0x30 = ASCII中的'0'。它看起来像你对我要传递的16位十六进制的两个字节,与0-7位第一和第二8-15,也就是说你想传递的4-7位
- 十六进制数字对于位8-11位
- 十六进制数字0-3
- 十六进制数字的位12-15
- 十六进制数字
我们会需要更多的数据点,可以肯定的,但这种适合你上面的例子:
bit 0 set encodes to string "0100" = 0x30 0x31 0x30 0x30
bit 1 set "0200" = 0x30 0x32 0x30 0x30
bit 2 set "0400" = 0x30 0x34 0x30 0x30
0+2 "0500" = 0x30 0x30 0x30 0x30
0+9 "0102" = 0x30 0x31 0x30 0x32
0,1,2,3,4,5,9 "3F02" = 0x33 0x46 0x30 0x32
即在Java中,如果你有你的位在单个整数n
你可能想
String output = Integer.toHexString((n >> 4) & 0xf)
+ Integer.toHexString(n & 0xf)
+ Integer.toHexString((n >> 12) & 0xf)
+ Integer.toHexString((n >> 8) & 0xf);
byte[] data = output.toUpperCase().getBytes("ASCII");
通过串
,或者
byte[] data = new byte[4];
data[0] = (byte)((n >> 4) & 0xf);
data[1] = (byte)(n & 0xf);
data[2] = (byte)((n >> 12) & 0xf);
data[3] = (byte)((n >> 8) & 0xf);
for(int i = 0; i < 4; ++i) {
data[i] += (data[i] < 10) ? '0' : ('A' - 10);
}
避免串。
为了解析四个字节返回到单个int,你可以使用
int bits = (((data[0] & 0xf) + ((data[0] >= 'A') ? 9 : 0)) << 4)
| ((data[1] & 0xf) + ((data[1] >= 'A') ? 9 : 0))
| (((data[2] & 0xf) + ((data[2] >= 'A') ? 9 : 0)) << 12)
| (((data[3] & 0xf) + ((data[3] >= 'A') ? 9 : 0)) << 8);
显然没有输入检查这里 - 我假设,我们得到预期的格式输入。括号中的主要内容应该只是解析字符串中的一个十六进制数字 - 您可以重构它或者实现更强大的功能。
来源
2012-04-05 09:19:23
Rup
您的“0位检查=> 0x30,0x31,0x30,0x30”示例背后的逻辑是什么? – 2012-04-05 08:47:52
我使用win程序,向打印机发送命令,并从COM端口监视API中捕获此示例。 – smie 2012-04-05 08:50:27
我们无法理解它。你能向我们展示更多可能的组合和例子吗? – adarshr 2012-04-05 08:56:15