通道、缓冲区、选择器和NIO

通道(Channel)

  1. 通道的定义:用于源节点与目标节点的连接。在 Java NIO 中负责缓冲区中数据的传输。Channel 本身不存储数据,因此需要配合缓冲区进行传输。

  2. 通道的主要实现类
    java.nio.channels.Channel 接口:
    |–FileChannel
    |–SocketChannel
    |–ServerSocketChannel
    |–DatagramChannel

  3. 获取通道
    ①.Java 针对支持通道的类提供了 getChannel() 方法
    本地 IO:FileInputStream/FileOutputStream、RandomAccessFile
    网络 IO:Socket、ServerSocket、DatagramSocket
    ②.在 JDK 1.7 中的 NIO.2 针对各个通道提供了静态方法 open()
    ③.在 JDK 1.7 中的 NIO.2 的 Files 工具类的 newByteChannel()

  4. 通道之间的数据传输
    transferFrom()、 transferTo()

  5. 分散(Scatter)与聚集(Gather)
    ① 分散读取(Scattering Reads):将通道中的数据分散到多个缓冲区中
    ② 聚集写入(Gathering Writes):将多个缓冲区中的数据聚集到通道中

  6. 字符集:Charset
    ① 编码:字符串 -> 字节数组
    ② 解码:字节数组 -> 字符串

缓冲区(Buffer)

  1. 缓冲区(Buffer):在 Java NIO 中负责数据的存取。缓冲区就是数组。用于存储不同数据类型的数据,根据数据类型不同(boolean 除外),提供了相应类型的缓冲区:
    ByteBuffer、 CharBuffer、ShortBuffer、IntBuffer
    LongBuffer、 FloatBuffer、DoubleBuffer
    上述缓冲区的管理方式几乎一致,通过 allocate() 获取缓冲区
  2. 缓冲区存取数据的两个核心方法:
    put() : 存入数据到缓冲区中
    get() : 获取缓冲区中的数据
  3. 缓冲区中的四个核心属性:
    ① capacity : 容量,表示缓冲区中最大存储数据的容量。一旦声明不能改变。
    ② limit : 界限,表示缓冲区中可以操作数据的大小。(limit 后数据不能进行读写)
    ③ position : 位置,表示缓冲区中正在操作数据的位置。
    ④ mark : 标记,表示记录当前 position 的位置。可以通过 reset() 恢复到 mark 的位置
    ⑤ 0 <= mark <= position <= limit <= capacity
  4. 直接缓冲区与非直接缓冲区:
    ① 非直接缓冲区:通过 allocate() 方法分配缓冲区,将缓冲区建立在 JVM 的内存中
    ② 直接缓冲区:通过 allocateDirect() 方法分配直接缓冲区,将缓冲区建立在物理内存中。可以提高效率

选择器(Selector)

选择器(selector)是 SelectableChannel 的多路复用器。用于监控 SelectableChannel 的 IO 状况。例子如下:

 	//1. 获取通道
   	SocketChannel sChannel = SocketChannel.open(new InetSocketAddress("127.0.0.1", 9898));
   	//2. 切换非阻塞模式
   	sChannel.configureBlocking(false);
   	//3. 获取选择器
   	Selector selector = Selector.open();
   	//4. 将通道注册到选择器上, 并且指定“监听接收事件”
   	sChannel.register(selector, SelectionKey.OP_ACCEPT);

通道、缓冲区、选择器和NIO_第1张图片

NIO中常见的类以及对应的方法

	Paths 提供的 get() 方法用来获取 Path 对象:
		Path get(String first, String … more) : 用于将多个字符串串连成路径。
	Path 常用方法:
		boolean endsWith(String path) : 判断是否以 path 路径结束
		boolean startsWith(String path) : 判断是否以 path 路径开始
		boolean isAbsolute() : 判断是否是绝对路径
		Path getFileName() : 返回与调用 Path 对象关联的文件名
		Path getName(int idx) : 返回的指定索引位置 idx 的路径名称
		int getNameCount() : 返回Path 根目录后面元素的数量
		Path getParent() :返回Path对象包含整个路径,不包含 Path 对象指定的文件路径
		Path getRoot() :返回调用 Path 对象的根路径
		Path resolve(Path p) :将相对路径解析为绝对路径
		Path toAbsolutePath() : 作为绝对路径返回调用 Path 对象
		String toString() : 返回调用 Path 对象的字符串表示形式
	Files常用方法:
		Path copy(Path src, Path dest, CopyOption … how) : 文件的复制
		Path createDirectory(Path path, FileAttribute … attr) : 创建一个目录
		Path createFile(Path path, FileAttribute … arr) : 创建一个文件
		void delete(Path path) : 删除一个文件
		Path move(Path src, Path dest, CopyOption…how) : 将 src 移动到 dest 位置
		long size(Path path) : 返回 path 指定文件的大小
	Files常用方法:用于判断
		boolean exists(Path path, LinkOption … opts) : 判断文件是否存在
		boolean isDirectory(Path path, LinkOption … opts) : 判断是否是目录
		boolean isExecutable(Path path) : 判断是否是可执行文件
		boolean isHidden(Path path) : 判断是否是隐藏文件
		boolean isReadable(Path path) : 判断文件是否可读
		boolean isWritable(Path path) : 判断文件是否可写
		boolean notExists(Path path, LinkOption … opts) : 判断文件是否不存在
		public static  A readAttributes(Path path,Class type,LinkOption... options) : 获取与 path 指定的文件相关联的属性。
	Files常用方法:用于操作内容
		SeekableByteChannel newByteChannel(Path path, OpenOption…how) : 获取与指定文件的连接,how 指定打开方式。
		DirectoryStream newDirectoryStream(Path path) : 打开 path 指定的目录
		InputStream newInputStream(Path path, OpenOption…how):获取 InputStream 对象
		OutputStream newOutputStream(Path path, OpenOption…how) : 获取 OutputStream 对象

你可能感兴趣的:(通道、缓冲区、选择器和NIO)