Java NIO中的 ServerSocketChannel 是一个可以监听新进来的TCP连接的通道, 就像标准IO中的ServerSocket一样.ServerSocketChannel类在 java.nio.channels包中. 这里有个例子: ServerSocketChannel serverSocketChannel = ServerSocketChannel.open(); serverSocketChannel.socket().bind(new InetSocketAddres…
Java NIO开始支持scatter/gather,scatter/gather用于描述从Channel(译者注:Channel在中文经常翻译为通道)中读取或者写入到Channel的操作. 分散(scatter)从Channel中读取是指在读操作时将读取的数据写入多个buffer中.因此,Channel将从Channel中读取的数据“分散(scatter)”到多个Buffer中. 聚集(gather)写入Channel是指在写操作时将多个buffer的数据写入同一个Channel,因此,Cha…
RandomAccessFile RandomAccessFile是用来访问那些保存数据记录的文件的,你就可以用seek( )方法来访问记录,并进行读写了.这些记录的大小不必相同:但是其大小和位置必须是可知的.但是该类仅限于操作文件. RandomAccessFile不属于InputStream和OutputStream类系的.实际上,除了实现DataInput和DataOutput接口之外(DataInputStream和DataOutputStream也实现了这两个接口),它和这两个类系毫不…
缓冲区 传统的流和通道的对比 流 通道 慢 快 处理简单 处理复杂 单字节的传输 一块数据的传输 - Java.io.*已经重新写过 - 是对流的模拟 单向的 双向的 可直接访问 必须通过Buffer和通道打交道 流与块的比较 原来的 I/O 库(在 java.io.*中) 与 NIO 最重要的区别是数据打包和传输的方式.正如前面提到的,原来的 I/O 以流的方式处理数据,而 NIO 以块的方式处理数据. 面向流 的 I/O 系统一次一个字节地处理数据.一个输入流产生一个字节的数据,一个输出流消…
Java 语言被定义为基于Unicode.一个字符实体由二个字节表示(如果是用UCS-2).但众多文件和数据流都是基于其它字符编码并以byte传输,操作文件内容就成了一个问题. 操作一个文件首先要对文件内容进行解码,文件内容是二进制数据(也可以认为是字节流),我们要把内容解码为JAVA可以理解的一个个字符(Unicode). 修改完成后还要按输出编码把文件内容编码成对应的二进制内容,再输出到对应地点. 读取文件内容后要用CharBuffer做decode,才能获取字符内容CharBuffer.…
Java NIO Tutorial 地址:http://tutorials.jenkov.com/java-nio/index.html Java NIO系列教程译文地址:http://ifeve.com/java-nio-all/ 以下是我拜读过程中摘抄的部分内容,并且加了一些内容.笔记,姑且叫<快学Java NIO>,方便以后再翻阅学习 附上一个Java NIO实现的demo,多人网络聊天室 Java NIO 由以下几个核心部分组成: Channels Buffers Selectors…
Socket通道 Socket通道和文件通道有着不一样的特征: Socket通道类可以运行于非阻塞模式,并且是可选的.这两个特征可以激活大程序(如网络服务和中间件组件)巨大的可伸缩性和灵活性,因此再也没有为每个Socket连接添加一个线程的必要.这一特性避免了管理大量线程所需的上下文交换总开销,借助NIO,一个或几个线程就可以管理成百上千个Socket连接,并且没有或只有很少的性能损失 全部的Socket通道类(SocketChannel,ServerSocketChannel,Datagram…
Java NIO中的 ServerSocketChannel 是一个可以监听新进来的TCP连接的通道, 就像标准IO中的ServerSocket一样.ServerSocketChannel类在 java.nio.channels包中. 这里有个例子: 01 ServerSocketChannel serverSocketChannel = ServerSocketChannel.open(); 02   03 serverSocketChannel.socket().bind(new InetS…
Java NIO SocketChannel Java NIO SocketChannel是连接到TCP网络socket(套接字)的通道.Java NIO相当于Java Networking的socket(套接字).有两种创建SocketChannel的方法: 打开SocketChannel并连接到互联网上的某个服务器. 当一个连接接入到一个ServerSocketChannel时,SocketChannel就会被创建. 打开一个SocketChannel 打开一个SocketChannel:…
Java NIO中的 ServerSocketChannel 是一个可以监听新进来的TCP连接的通道, 就像标准IO中的ServerSocket一样.ServerSocketChannel类在 java.nio.channels包中. 这里有个例子: 01 ServerSocketChannel serverSocketChannel = ServerSocketChannel.open(); 02   03 serverSocketChannel.socket().bind(new InetS…