java byte b = 0x80;

因为什么0x 开头的是16进制,编译的时候会自动转成整数,而这个整数超过了byte的长度(byte取值范围是-128 ~ 127), 而0x80转为十进制 = 128所以报损失精度了,编译不过的

// 十进制转化为十六进制,结果为C8。
Integer.toHexString( 200 );
 
// 十六进制转化为十进制,结果140。
Integer.parseInt( "8C" , 16 );



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
该代码存在以下问题: 1. `DynamicByteBuffer()` 方法名应该改为构造方法名 `Main()`; 2. `Rand` 变量没有定义,可能会导致编译错误,建议注释掉该行代码; 3. `put()` 方法中的 `byteBuffer.put(newData)` 应该改为 `byteBuffer.put(newData, 0, newData.length)`,因为 `newData` 数组可能比 `byteBuffer` 剩余的空间大,这会导致 `BufferOverflowException` 异常; 4. `put()` 方法中的 `if (requiredCapacity > data.length)` 语句中的判断条件应该改为 `requiredCapacity > byteBuffer.capacity()`,因为 `data.length` 在之后可能被扩容,但是 `byteBuffer.capacity()` 不会改变。 下面是修改后的代码: ```java import java.nio.ByteBuffer; import java.util.Arrays; public class Main { private static byte STX = 0x02; // 2 开始位 //private static byte Rand = AccesscEntrty.ACCRandom();//随机数 public static void main(String[] args) { Main dynamicBuffer = new Main(); dynamicBuffer.put(new byte[] {STX, 0x2C}); byte[] result = dynamicBuffer.toArray(); for (byte b : result) { System.out.println(b); } } private static final int INITIAL_SIZE = 9; private byte[] data; private ByteBuffer byteBuffer; public Main() { data = new byte[INITIAL_SIZE]; byteBuffer = ByteBuffer.wrap(data); } public void put(byte[] newData) { int requiredCapacity = byteBuffer.position() + newData.length; if (requiredCapacity > byteBuffer.capacity()) { int newSize = Math.max(byteBuffer.capacity() * 2, requiredCapacity); byte[] newDataArray = Arrays.copyOf(data, newSize); byteBuffer = ByteBuffer.wrap(newDataArray); byteBuffer.position(data.length); } byteBuffer.put(newData, 0, newData.length); } public byte[] toArray() { return Arrays.copyOf(data, byteBuffer.position()); } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值