【java】java中进制、byte、String转换问题

文章介绍了如何发送byte数组指令,包括固定和动态指令的生成。在处理TCPMODBUS协议时,16进制常被使用。文章还讨论了byte和int之间的转换问题,特别是涉及范围限制和无符号转换。此外,利用Hutool库进行byte字符串的互转,并提到了十进制转16进制字符串的方法。
摘要由CSDN通过智能技术生成

在博主之前的文章中,有简单介绍过二进制,除了二进制,16进制也是常用的,例如在博主接触的tcp(modbus)协议中 16进制就经常出现。

如何发送byte数组指令

我们假设在对接中,知道固定的指令是16进制数组 代码示例如下:

// 16进制为例
byte rq = new byte[]{0x00,0x00,0x00,0x00,0x01,0x03}

// 在netty中为例:
channelHandlerContext.writeAndFlush(rq );
// 需要先配置编码器            
// socketChannel.pipeline().addLast("ByteArrayDecoder", new ByteArrayDecoder());


如何发送动态byte数组指令

上述例子中, 我们是知道指令的,而且指令是固定的,换句话说,byte数组里面的内容,是我们加上0x前缀写死的,那假设我们的指令并不是固定的,是可变的呢?

伪代码还原一下场景:

int id = ?;
byte rq ;
if (id == 3){
    rq= new byte[]{0x00,0x00,0x00,0x00,0x01,0x03}
 } else if (id == 6){
     rq= new byte[]{0x00,0x00,0x00,0x00,0x01,0x06}
} else if(id == 9){
    rq= new byte[]{0x00,0x00,0x00,0x00,0x01,0x09}
}else{
	// other
}


如果id是有限个,我们还可以如上定义,那如果id是未知个呢?
如果基础比较差的同学可能会产生疑惑,不知道该如何定义了。

我们只需要直接将int强转byte就好了

    rq= new byte[]{0x00,0x00,0x00,0x00,0x01,(byte) id};

byte和int互转问题

上文提到 int强转byte就好,但是byte和int之间互转会有个范围问题:

		int t = 255;
		// (byte范围是-128-127)
        byte tt = (byte) t; // -1
        // 而byte是可以直接转int的
        int ttt = tt; // -1
       

可以看到byte为负数时,直接转回int就会出现问题了,那我们要如何得到int原来的数呢?我们需要将 tt 和 0xFF 做一次与运算,得到无符号数
(前提是知道int一定是正数)。

int res = tt & 0xFF; //255
	

说了那么多,可能有的同学会疑惑,为什么会出现byte范围的数据呢?
比如别人给过来的tcp数据格式是:00 00 00 00 00 04 01 02 03 FF ,(16进制),最后这个FF字节,就超过范围了。

科普一个小知识:大胆点,这个结果是true在这里插入图片描述

byte和byte字符串互转问题

还是以16进制为例,我们需要引入hutool包,

     	   <dependency>
                <groupId>cn.hutool</groupId>
                <artifactId>hutool-all</artifactId>
                <version>5.0.7</version>
            </dependency>
	// bytes to hexStr
    byte[] bytes  = new byte[]{0x00,0x00,0x00,0x00,0x01};
    // ”0000000001“
    String hexStr =   HexUtil.encodeHexStr(bytes);
	// hexStr to bytes
	byte[] b = HexUtil.decodeHex(hexStr);

十进制转16进制字符串

	String str = Integer.toHexString(11); // b

如果需要占两位长度 ,即: 0b ,则手动判断str的长度, 拼接一个0即可

str += "0"

还是有个常识性的问题,基础好的同学别看,看了反而会迷糊。

基础差的同学 可以看看:
我们只能手动声明0x 来表示16进制,但它并不是一个类型,
不能像10进制直接用long和int类型来表示

	 		byte a = 0x01; // 16进制中01 的byte值
	        int b = 0x01;  //  16进制中01 的int值

所以我们在代码中,一般都是用byte 或者String hexStr 来表示16进制,
还是那个例子 (byte) 0xFF 和 byte -1 值是相等的

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

孟秋与你

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值