easy-algorithm-interview-an.../code-languages/java/Java Byte数组与Long的相互转化.md

1.5 KiB
Raw Blame History

1.java.nio中的Buffer

java.nio(NEW IO)是JDK 1.4版本开始引入的一个新的IO API可以替代标准的Java IO API。NIO与原来的IO有同样的作用和目的但是使用的方式完全不同 NIO支持面向缓冲区的、基于通道的IO操作。 NIO将以更加高效的方式进行文件的读写操作。

而缓冲区Buffer是一个容器对象底层的存储结构为一个数组。在NIO中所有的数据都是缓冲区来处理的。而使用缓冲区的好处显而易见第一可以减少实际物理的读写次数第二缓冲区创建初始就被分配了内存这个内存空间一直在被重用可以减少动态分配和回收内存的次数。

在nio库中Buffer是一个抽象类具体的实现类可以参考下图

在这里插入图片描述
在这里插入图片描述

2.long转byte数组

   public static byte[] toByteArray(long value) {
        return ByteBuffer.allocate(Long.SIZE / Byte.SIZE).putLong(value).array();
    }

3.byte数组转long

    public static long byteArrayToLong(byte[] bytes) {
        ByteBuffer buffer = ByteBuffer.allocate(8);
        buffer.put(bytes, 0, bytes.length);
        buffer.flip();
        return buffer.getLong();
    }

4.allocate

上面的allocate方法作用是从堆空间中分配一个容量大小为capacity的byte数组作为缓冲区的byte数据存储器所有的数据操作都是在这个byte数组中完成的。