内存映射文件MappedByteBuffer和Buffer的Scattering与Gathering

上一篇讲到的DirectByteBuffer继承自MappedByteBufferjava

1、MappedByteBuffer缓存

MappedByteBuffer的定义:app

A direct byte buffer whose content is a memory-mapped region of a file.dom

直接缓存,内容是一个内存映射文件。socket

建立测试类测试

public class NioTest9 {
    public static void main(String[] args) throws  Exception {
        RandomAccessFile randomAccessFile = new RandomAccessFile("NioTest9.txt","rw");
        FileChannel fileChannel =  randomAccessFile.getChannel();
        MappedByteBuffer mappedByteBuffer = fileChannel.map(FileChannel.MapMode.READ_WRITE, 0,5);
        mappedByteBuffer.put(0,(byte)'a');
        mappedByteBuffer.put(3,(byte)'b');

        randomAccessFile.close();
    }
}

 建立NioTest9.tex文件操作系统

 

 运行程序,用记事本打开3d

操做的是堆外内存,堆外内存写入到文件由操做系统控制。server

 

2、排他锁和共享锁blog

实际用的比较少

/**
 * 
 * 共享锁: 全部程序都能多共享的部分进行读
 * 排他锁: 只有一个程序对锁定的部分进行写操做
 * 
 */
public class NioTest10 {

    public static void main(String[] args) throws Exception {
        RandomAccessFile randomAccessFile = new RandomAccessFile("NioTest10.txt", "rw");

        FileChannel fileChannel = randomAccessFile.getChannel();

       FileLock fileLock = fileChannel.lock(3,6,true);

        System.out.println("valid:" + fileLock.isValid());

        System.out.println("lock type:" + fileLock.isShared());

        fileLock.release();

        randomAccessFile.close();
    }
}

  

 

3、关于Buffer的Scattering(散开)与Gathering(收集)

/**
 *
 * 关于Buffer的Scattering(散开)与Gathering(收集)
 *
 */
public class NioTest11 {

    public static void main(String[] args) throws Exception {

        ServerSocketChannel serverSocketChannel = ServerSocketChannel.open();

        InetSocketAddress address = new InetSocketAddress(8899);

        serverSocketChannel.socket().bind(address);

        int messageLength = 2 + 3 + 4;
        ByteBuffer[] buffers = new ByteBuffer[3];
        buffers[0] = ByteBuffer.allocate(2);
        buffers[1] = ByteBuffer.allocate(3);
        buffers[2] = ByteBuffer.allocate(4);

        SocketChannel socketChannel = serverSocketChannel.accept();

        while (true){
            int byteRead = 0;
            while (byteRead < messageLength){
                long r = socketChannel.read(buffers);
                byteRead += r;

                System.out.println("bytesRead:" + byteRead);

                Arrays.asList(buffers).stream().map(buffer -> "position:" + buffer.position() +",limit:" + buffer.limit() + " 值:" + buffer.toString()).forEach(System.out::println);
            }

            Arrays.asList(buffers).forEach(buffer -> {
                buffer.flip();
            });

            long byteWritten = 0;
            while (byteWritten < messageLength){
                long r = socketChannel.write(buffers);
                byteWritten += r;
            }


            Arrays.asList(buffers).forEach(bufffer -> {
                bufffer.clear();
            });

            System.out.println("bytesRead:" + byteRead + ",byteWritten: " + byteWritten +", messageLength:" + messageLength);
        }

    }
}

  使用Telnet发送,输出结果以下图:

相关文章
相关标签/搜索