NIO简介详解

一、Java NIO简介 Java New IO Non Blocking IO,从java1.4版本就开始引入了新的IO API,可以替代标准的Java IO API。NIO与原来的IO有同样的作用和目的,但是使用的方式完全不同,NIO...

NIO之缓冲区(Buffer)的数据存取详解

缓冲区(Buffer):  一个用于特定基本数据类行的容器。有java.nio包定义的,所有缓冲区都是抽象类Buffer的子类。  Java NIO中的Buffer主要用于与NIO通道进行交互,数据是从通道读入到缓冲区,从缓冲区写入通道中的...

NIO之直接缓冲区与非直接缓冲区详解

直接缓冲区与非直接缓冲区的概念 一、非直接缓冲区 1)创建方式 通过 static ByteBuffer allocate(int capacity) 创建的缓冲区,在JVM中内存中创建,在每次调用基础操作系统的一个本机...

NIO之通道(Channel)的原理与获取以及数据传输与内存映射文件详解

通道(Channel)   由java.nio.channels包定义的,Channel表示IO源与目标打开的连接,Channel类似于传统的“流”,只不过Channel本身不能直接访问数据,Channel只能与Buffer进行交互。通道...

NIO之Channel聚集(gather)写入与分散(scatter)读取详解

Channel聚集(gather)写入 聚集写入( Gathering Writes)是指将多个 Buffer 中的数据“聚集”到 Channel。 特别注意:按照缓冲区的顺序,写入 po...

NIO之阻塞IO与非阻塞IO详解

阻塞IO   传统的 IO 流都是阻塞式的。   也就是说,当一个线程调用 read() 或 write()时,该线程被阻塞,直到有一些数据被读取或写入,该线程在此期间不能执行其他任务。...

NIO之DatagramChannel详解

Java NIO中的DatagramChannel是一个能收发UDP包的通道。操作步骤:  1)打开 DatagramChannel  2)接收/发送数据同样它也支持NIO的非阻塞模式操作,例如: 1 @Tes...

NIO之管道 (Pipe)详解

Java NIO 管道是2个线程之间的单向数据连接。Pipe有一个source通道和一个sink通道。数据会被写到sink通道,从source通道读取。 代码使用示例: 1 @Test 2...

NIO之Charset类字符编码对象详解

Charset类字符编码对象 介绍 java中使用Charset来表示编码对象 This class defines methods for creating decoders and encoders and for retri...

如何通俗的理解spring的控制反转、依赖注入、面向切面编程等等详解

之前一直不理解spring的一些基础特性是什么意思,虽然网上的解释也很多,但是由于我比较笨,就是看不懂,知道最近才稍微了解,下面就以通俗讲解的方式记录下来。 前言 假设我是一个没有开店经验的小老板,准备开个小超市。 方案1:自己去找店...