java bytebuffer getint,java – ByteBuffer getInt()问题

So where is the implementation of the getInt() method?

ByteBuffer确实是一个抽象类.有几种方法可以创建字节缓冲区:

在我的JDK中,这些创建了内部类HeapByteBuffer和DirectByteBuffer的实例.它们各自的getInt函数如下:

// HeapByteBuffer

public int getInt() {

return Bits.getInt(this, ix(nextGetIndex(4)), bigEndian);

}

public int getInt(int i) {

return Bits.getInt(this, ix(checkIndex(i, 4)), bigEndian);

}

// DirectByteBuffer

private int getInt(long a) {

if (unaligned) {

int x = unsafe.getInt(a);

return (nativeByteOrder ? x : Bits.swap(x));

}

return Bits.getInt(a, bigEndian);

}

public int getInt() {

return getInt(ix(nextGetIndex((1 << 2))));

}

public int getInt(int i) {

return getInt(ix(checkIndex(i, (1 << 2))));

}

在上面,nativeByteOrder和bigEndian是两个布尔成员,分别指示 – 并且有点冗余 – 是否配置的字节顺序:(a)匹配本机字节顺序; (b)是大端.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中的ByteBuffer是一个用于操作字节数据的缓冲区。它提供了一种方便的方式来读取、写入和操作字节数据。下面是一些Java中使用ByteBuffer的常见操作: 1. 创建ByteBuffer对象: ```java ByteBuffer buffer = ByteBuffer.allocate(1024); // 创建一个容量为1024字节的ByteBuffer对象 ``` 2. 写入数据到ByteBuffer: ```java buffer.put((byte) 65); // 写入一个字节数据 buffer.putChar('A'); // 写入一个字符数据 buffer.putShort((short) 123); // 写入一个短整型数据 buffer.putInt(456); // 写入一个整型数据 buffer.putLong(789L); // 写入一个长整型数据 buffer.putFloat(3.14f); // 写入一个浮点型数据 buffer.putDouble(2.71828); // 写入一个双精度浮点型数据 buffer.put("Hello".getBytes()); // 写入一个字节数组 ``` 3. 从ByteBuffer中读取数据: ```java buffer.flip(); // 切换为读模式 byte b = buffer.get(); // 读取一个字节数据 char c = buffer.getChar(); // 读取一个字符数据 short s = buffer.getShort(); // 读取一个短整型数据 int i = buffer.getInt(); // 读取一个整型数据 long l = buffer.getLong(); // 读取一个长整型数据 float f = buffer.getFloat(); // 读取一个浮点型数据 double d = buffer.getDouble(); // 读取一个双精度浮点型数据 byte[] bytes = new byte[buffer.remaining()]; // 创建一个字节数组来存储剩余的字节数据 buffer.get(bytes); // 读取剩余的字节数据到字节数组中 ``` 4. 清空ByteBuffer: ```java buffer.clear(); // 清空ByteBuffer,将position、limit和mark重置为初始状态 ``` 5. 使用ByteBuffer的其他方法: ```java buffer.position(4); // 设置position的位置 buffer.limit(8); // 设置limit的位置 buffer.mark(); // 标记当前position的位置 buffer.reset(); // 将position重置为mark的位置 buffer.rewind(); // 将position重置为0,不改变limit和mark的位置 buffer.remaining(); // 返回剩余可读取的字节数 buffer.hasRemaining(); // 判断是否还有剩余的字节可读取 ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值