zoukankan      html  css  js  c++  java
  • [翻译] java NIO Channel

    原文地址;http://tutorials.jenkov.com/java-nio/channels.html

    JAVA NIO channels和流的概念很像,下面是他们的一些区别:

    • 你可以对channel进行读写,流只能一种操作(读或写)。
    • channel可以异步的读写。
    • channel总是读入、写出到buffer。

    根据上面提到的,你可以从channel中读取数据到buffer中,也可以从buffer中写入数据到channel中。下即可解释:

    JAVA NIO: channels读入数据到buffers,buffers写入数据到channels

     

    Channel 实现

    下面是JAVA NIO 中最重要的channel的实现。

    • FileChannel
    • DatagramChannel
    • SocketChannel
    • ServerSocketChannel

    FileChannel从文件中读写数据。

    DatagramChannel通过UDP读写数据。

    SocketChannel通过TCP读写数据。

    ServerSocketChannel像一个web server那样,允许你监听TCP连接。每一个连接都会产生一个SocketChannel。

    一个简单的Channel的例子:

    下面是一个简单的使用FileChannel的例子,读取一些数据到Buffer中。

     1     RandomAccessFile aFile = new RandomAccessFile("data/nio-data.txt", "rw");
     2     FileChannel inChannel = aFile.getChannel();
     3 
     4     ByteBuffer buf = ByteBuffer.allocate(48);
     5 
     6     int bytesRead = inChannel.read(buf);
     7     while (bytesRead != -1) {
     8 
     9       System.out.println("Read " + bytesRead);
    10       buf.flip();
    11 
    12       while(buf.hasRemaining()){
    13           System.out.print((char) buf.get());
    14       }
    15 
    16       buf.clear();
    17       bytesRead = inChannel.read(buf);
    18     }
    19     aFile.close();

    注意flip()方法的调用,开始你读取数据到buffer,然后转换,即由读转换到写,然后从buffer中读取数据。这个问题将会在下一节的Buffer中详细的介绍。

  • 相关阅读:
    Jenkins知识地图
    PageObject&PageFactory
    robot framework-databaselibaray库使用(python)
    robot framework环境搭建
    使用instantclient_11_2 和PL/SQL Developer工具包连接oracle 11g远程数据库(转)
    (转)pip和easy_install使用方式
    图解:如何在LINUX中安装VM-Tools
    ANT简明教程[转载]
    Linux常用命令
    oracle数据分组
  • 原文地址:https://www.cnblogs.com/hitandrew/p/3339962.html
Copyright © 2011-2022 走看看