Java NIO学习笔记六 SocketChannel 和 ServerSocketChannel
Java NIO SocketChannel
Java NIO SocketChannel是连接到TCP网络socket(套接字)的通道。Java NIO相当于Java Networking的socket(套接字)。有两种创建SocketChannel的方法
:
- 打开
SocketChannel
并连接到互联网上的某个服务器。 - 当一个连接接入到一个
ServerSocketChannel时,SocketChannel就会被创建
。
打开一个SocketChannel
打开一个SocketChannel
:
SocketChannel socketChannel = SocketChannel.open();
socketChannel.connect(new InetSocketAddress(“http://jenkov.com”,80));
关闭SocketChannel
使用完SocketChannel后,可以
通过调用SocketChannel的close()
方法,将其关闭。
代码展示:
socketChannel.close();
从SocketChannel读取数据
要从SocketChannel
您那里读取数据,可以调用read()
方法。
代码:
ByteBuffer buf = ByteBuffer.allocate(48); int bytesRead = socketChannel.read(buf);
首先:进行Buffer
分配,从SocketChannel中读取的数据到Buffer中
。
然后:调用SocketChannel的read()
方法。将数据从SocketChannel中读
入Buffer
。返回值是int,表示有多少字节数据被读入到Buffer缓存中。如果返回-1,则到达端到端(连接已关闭)。
数据写入SocketChannel
SocketChannel
使用SocketChannel的write()
方法来写入数据,该方法使用Buffer做
参数。
代码展示:
String newData =“要写入文件的新字符串...”+ System.currentTimeMillis(); ByteBuffer buf = ByteBuffer.allocate(48);
buf.clear();
buf.put(newData.getBytes()); buf.flip(); while(buf.hasRemaining()){
channel.write(buf);
}
注意SocketChannel.write()
在while循环中如何调用该方法。不能保证write()
方法写入SocketChannel的字节数。因此,我们重复调用write()
,直到Buffer
没有字节可以写入。
非阻塞模式
您可以将SocketChannel设置为非阻塞模式。在非阻塞模式下,你可以以异步方式调用connect()
,read()
并write()方法
。
connect()
如果SocketChannel
是非阻塞模式,并且您调用connect()
,方法可能会在建立连接之前返回。要确定连接是否建立,可以调用finishConnect()
方法,如下所示:
socketChannel.configureBlocking(假);
socketChannel.connect(new InetSocketAddress(“http://jenkov.com”,80)); while(!socketChannel.finishConnect()){
//做其他的事情
}
write()
在非阻塞模式下,write()
方法在不写任何数据的情况下可以返回。因此,你需要在循环中调用write()方法。代码同上。
read()
在非阻塞模式下,read()
方法可以在没有读取任何数据的情况下返回。因此,您需要注意返回的值int
,这表示读取了多少个字节。
具有选择器的非阻塞模式
这种非阻塞模式的SocketChannel
效果要比Selector好点
。通过使用Selector
注册一个或一个以上SocketChannel
,你可以访问已经准备读、写通道的Selector。
Java NIO ServerSocketChannel
Java NIO ServerSocketChannel是可以监听接入TCP连接的通道,就像ServerSocket
的Java标准网络一样。ServerSocketChannel类
位于java.nio.channels
包中。
java代码展示:
ServerSocketChannel serverSocketChannel = ServerSocketChannel.open(); serverSocketChannel.socket().bind(new InetSocketAddress(9999)); while(true){
SocketChannel socketChannel =
serverSocketChannel.accept(); //用socketChannel做一些事情...
}
开启ServerSocketChannel
通过调用ServerSocketChannel的open()
方法,你可以打开一个ServerSocketChannel
。
代码展示:
ServerSocketChannel serverSocketChannel = ServerSocketChannel.open();
关闭ServerSocketChannel
通过调用ServerSocketChannel的close()
方法来关闭ServerSocketChannel。这是怎么样的样子:
serverSocketChannel.close();
监听接入的连接
通过调用ServerSocketChannel的accept()
方法来监听传接入连接。当该accept()
方法返回时,它返回SocketChannel
一个传入连接。因此,accept()
方法阻塞直到有连接介入。
我们通常不会对单个连接进行监听,所以您可以在accept()
内部调用一个循环,来监听多个接入的连接。
代码展示:
while(true){
SocketChannel socketChannel = serverSocketChannel.accept(); //用socketChannel做一些事情...
}
非阻塞模式
ServerSocketChannel
可以设置为非阻塞模式。在非阻塞模式下,accept()
方法立即返回,如果没有连接,则返回null。因此,您必须检查返回值 SocketChannel
是否为空。
代码展示:
ServerSocketChannel serverSocketChannel = ServerSocketChannel.open(); serverSocketChannel.socket()。bind(new InetSocketAddress(9999));
serverSocketChannel.configureBlocking(false); while(true){
SocketChannel socketChannel =
serverSocketChannel.accept(); if(socketChannel!= null){
//用socketChannel做一些事情...
}
}
Java NIO学习笔记六 SocketChannel 和 ServerSocketChannel的更多相关文章
- Java IO学习笔记六:NIO到多路复用
作者:Grey 原文地址:Java IO学习笔记六:NIO到多路复用 虽然NIO性能上比BIO要好,参考:Java IO学习笔记五:BIO到NIO 但是NIO也有问题,NIO服务端的示例代码中往往会包 ...
- Java NIO 学习笔记(六)----异步文件通道 AsynchronousFileChannel
目录: Java NIO 学习笔记(一)----概述,Channel/Buffer Java NIO 学习笔记(二)----聚集和分散,通道到通道 Java NIO 学习笔记(三)----Select ...
- Java NIO 学习笔记(四)----文件通道和网络通道
目录: Java NIO 学习笔记(一)----概述,Channel/Buffer Java NIO 学习笔记(二)----聚集和分散,通道到通道 Java NIO 学习笔记(三)----Select ...
- Java NIO 学习笔记(三)----Selector
目录: Java NIO 学习笔记(一)----概述,Channel/Buffer Java NIO 学习笔记(二)----聚集和分散,通道到通道 Java NIO 学习笔记(三)----Select ...
- Java NIO 学习笔记(一)----概述,Channel/Buffer
目录: Java NIO 学习笔记(一)----概述,Channel/Buffer Java NIO 学习笔记(二)----聚集和分散,通道到通道 Java NIO 学习笔记(三)----Select ...
- Java NIO学习笔记
Java NIO学习笔记 一 基本概念 IO 是主存和外部设备 ( 硬盘.终端和网络等 ) 拷贝数据的过程. IO 是操作系统的底层功能实现,底层通过 I/O 指令进行完成. 所有语言运行时系统提供执 ...
- Java NIO 学习笔记(二)----聚集和分散,通道到通道
目录: Java NIO 学习笔记(一)----概述,Channel/Buffer Java NIO 学习笔记(二)----聚集和分散,通道到通道 Java NIO 学习笔记(三)----Select ...
- Java NIO 学习笔记(七)----NIO/IO 的对比和总结
目录: Java NIO 学习笔记(一)----概述,Channel/Buffer Java NIO 学习笔记(二)----聚集和分散,通道到通道 Java NIO 学习笔记(三)----Select ...
- Java NIO 学习笔记(五)----路径、文件和管道 Path/Files/Pipe
目录: Java NIO 学习笔记(一)----概述,Channel/Buffer Java NIO 学习笔记(二)----聚集和分散,通道到通道 Java NIO 学习笔记(三)----Select ...
随机推荐
- java并发程序——BlockingQueue
概述 BlockingQueue顾名思义'阻塞的队列',是指在:队列的读取行为被阻塞直到队列不为空时,队列的写入行为被阻塞直到队列不满时.BlockingQueue是java.util.concurr ...
- 使用Angular 4、Bootstrap 4、TypeScript和ASP.NET Core开发的Apworks框架案例应用:Task List
最近我为我自己的应用开发框架Apworks设计了一套案例应用程序,并以Apache 2.0开源,开源地址是:https://github.com/daxnet/apworks-examples,目的是 ...
- js获取一组不重复的随机数的方法
一.基本思路: 建立一个数组存放所有可以取到的值,每次从该数组中随机取走一个,放到新的数组中,直到完成. 二.实现方法 1.方法一: (1)创建一个数组arr,数组元素为所有可能出现元素的集合: (2 ...
- mybatis mapper.xml 写关联查询 运用 resultmap 结果集中 用 association 关联其他表 并且 用 association 的 select 查询值 报错 java.lang.IllegalArgumentException: Mapped Statements collection does not contain value for mybatis.map
用mybaits 写一个关联查询 查询商品表关联商品规格表,并查询规格表中的数量.价格等,为了sql重用性,利用 association 节点 查询 结果并赋值报错 商品表的mapper文件为Gooo ...
- 使用Nginx实现Tomcat集群负载均衡
概述 要解决的问题 环境准备以及问题解决思路 配置 测试 小结 一.概述 使用Nginx主要是来解决高并发情况下的负载均衡问题. 二.要解决的问题 1.最主要是负载均衡请求分发. 2.文件上传功能,只 ...
- 精益IT组织与分享式领导
精益IT组织 未来的组织将专注于同行业的产品或业务流--其他的一切,包括专家和管理者在内,都是为了让一线工作人员可以第一时间就做好,而又不会遇到任何麻烦.最大的制约不是技术:真正的挑战是变 ...
- Mybatis的mapper文件引起模块划分的思考
起因:项目中将公用的代码抽离到单独一个项目 cms-common.jar (注:公用的代码不只是工具类代码,包含service和dao等) 构建:每次构建项目 cms.war 的时候,需要引入cms- ...
- Nginx http和https 共存
nginx https 配置,添加证书启动https server { listen default_server; listen ; server_name _; ssl on; ssl_certi ...
- 互联网金融P2P主业务场景自动化测试
互联网金融P2P行业,近三年来发展迅速,如火如荼. 据不完全统计,全国有3000+的企业. “互联网+”企业,几乎每天都会碰到一些奇奇怪怪的bug,作为在互联网企业工 ...
- (基础篇 走进javaNIO)第一章-java的i/o演进之路
Java 是由 SUN公司在 1995 年首先发布 的编程语 言和计算平 台.这基础技术 支持最新 的程序 ,包括 实用程序 .游 戏和业 务应用程序 .J ava 在世界各地 的 8.5 亿 多 ...