java网络通信之非阻塞通信
java中提供的非阻塞类主要包含在java.nio,包括:
1、ServerSocketChannel:ServerSocket替代类,支持阻塞与非阻塞;
2、SocketChannel:Socket的替代类,支持阻塞与非阻塞;
3、Selector:为ServerSocketChannel监控接收连接就绪事件,为SocketChannel监控连接就绪、读和写事件;
4、SelctionKey:代表ServerSocketChannel及SocketChannel向Selector注册事件,当一个SelectionLKey对象位于Selector的selected-keys集合中时,就表示与这个SelectionKey相关的事件发生。
以上中,SocketChannel以及ServerSocketChannel均是SelectableChannel类的子类,而这个类又继承了Channel接口。
SelectableChannel类向Selector类注册来监控前者可能发生的事件,过程为:SelectionKey key = serverSocketChannel.register(selector,SelectionKey.OP_ACCEPT)。
SocketChannel中发送和接收数据的方法为:
1、read(ByteBuffer buffer):将接收到的数据存放在指定的buffer中;
2、write(ButeBuffer buffer):将buffer中的数据发送出去。
Buffer(抽象类,位于java.nio包):
Buffer的属性:
1、容量,表示缓冲区可以保存的数据数量;
2、极限,表示换从去的当前终点,不能对超过缓冲区极限的区域进行读写,说白了就是极限之前的数据是有效的,之后的无效,不能大于容量;
3、位置,表示缓冲区下一个读写单元的位置,每次读写时会改变这个数值,不能大于极限;
缓冲区改变三个属性的方法:
1、clear(),极限设置为容量,位置置为0;
2、flip(),把极限设置为位置,再把位置置为0;
3、rewind(),不改变极限,把位置置为0。
Buffer有很多子类:
1、ByteBuffer,没有构造方法,需要静态类:
1)、allocate(int capacity),返回ByteBuffer类对象,capacity指定缓冲区的大小;
2)、directAllocate(int capacity),同上,I/O操作速度快,但是系统开销大。
2、除boolean之外的其它基本类型都有buffer类,都有allocate(int capacity)静态方法返回实例;
3、MappedByteBuffer,ButeBuffer类的子类,把缓冲区和文件某个区域直接映射。
读写缓冲区的方法如下:
1、get(),冲缓冲区当前位置读取一个单元数据,读完后把位置加1;
2、get(int index),绝对读,从index位置读数据但不改位置;
3、put(),向缓冲区当前位置写一个数据,然后位置加1;
4、put(int index),绝对写,向index位置写数剧单不改位置。
字符编码Charset(java.nio)
该类实例代表特定的字符编码类型,其编码与解码的方法如下:
1、ByteBuffer encode(String str),将字符串str转换为Byte并保存在ByteBuffer中;
2、ByteBuffer encode(CharBuffer cb),同上;
3、CharBuffer decode(ByteBuffer b),将b转换为CharBuffer;
Charset类中有静态方法forName(String encode)返回Charset对象,参数指定编码类型;还有一个defaultCharset()返回本平台默认字符编码的Charset对象。
Channel(java.nio.channels)接口用于连接缓冲区与数据源或者数据目的地,数据源的数据经过通道到达缓冲区,然后缓冲区的数据再经过通道到达目的地,其中包括两个方法:
1、close(),关闭通道;
2、isOpen(),判断通道是否打开。
Channel的子接口很多:
1、ReadableByeChannel接口,声明read(ByteBuffer dst),把数据源的数据读入到ByteBuffer;
2、WriteByteChannel接口,声明write(ByteBuffer src),将ByteBuffer中的数据写入到目的地。
3、ScatterByteChannel接口,分散读取数据,单个读取操作能填充多个缓冲区,它提供了read(ByteBuffer[] src),将读取的数据依次填充到ByteBuffer各个元素中;
4、GatheringByteChannel接口,集中写入数据,声明了write(ByteBuffer[] scrs),将各个ByteBuffer写入到指定的目的地;
5、FileChannel类,实现了ByteChannel、ScatteringByteChannel和GatherByteChannel,不能new,只能通过FileInputStream、FileOutputStrem、RandomAccessFile的getChannel()返回相应的FileChannel。
6、SelectableChannel,支持阻塞和非阻塞的I/O,其方法包括:
1)、public SelectableChannel configureBlocking(boolean block) throws IOException,block为false时,表示为把SelectableChannel设置为非阻塞模式;
2)、isBlocking()判断SelectableChannel是否为阻塞模式;
3)、public SelectionKey register(Selector sel, int ops) throws ClosedChannelException;
4)、public SelectionKey register(Selector sel,int ops,Object attachment) throws ClosedChannelException,这两个方法均向Selector注册事件,其中Object为SelectionKey关联的一个附件。
java网络通信之非阻塞通信的更多相关文章
- Java NIO Socket 非阻塞通信
		
相对于非阻塞通信的复杂性,通常客户端并不需要使用非阻塞通信以提高性能,故这里只有服务端使用非阻塞通信方式实现 客户端: package com.test.client; import java.io. ...
 - 用Java实现非阻塞通信
		
用ServerSocket和Socket来编写服务器程序和客户程序,是Java网络编程的最基本的方式.这些服务器程序或客户程序在运行过程中常常会阻塞.例如当一个线程执行ServerSocket的acc ...
 - java并发之非阻塞算法介绍
		
在并发上下文中,非阻塞算法是一种允许线程在阻塞其他线程的情况下访问共享状态的算法.在绝大多数项目中,在算法中如果一个线程的挂起没有导致其它的线程挂起,我们就说这个算法是非阻塞的. 为了更好的理解阻塞算 ...
 - 【MPI学习4】MPI并行程序设计模式:非阻塞通信MPI程序设计
		
这一章讲了MPI非阻塞通信的原理和一些函数接口,最后再用非阻塞通信方式实现Jacobi迭代,记录学习中的一些知识. (1)阻塞通信与非阻塞通信 阻塞通信调用时,整个程序只能执行通信相关的内容,而无法执 ...
 - 利用Python中SocketServer 实现客户端与服务器间非阻塞通信
		
利用SocketServer模块来实现网络客户端与服务器并发连接非阻塞通信 版权声明 本文转自:http://blog.csdn.net/cnmilan/article/details/9664823 ...
 - UE4 Socket多线程非阻塞通信
		
转自:https://blog.csdn.net/lunweiwangxi3/article/details/50468593 ue4自带的Fsocket用起来依旧不是那么的顺手,感觉超出了我的理解范 ...
 - 【python】网络编程-SocketServer 实现客户端与服务器间非阻塞通信
		
利用SocketServer模块来实现网络客户端与服务器并发连接非阻塞通信.首先,先了解下SocketServer模块中可供使用的类:BaseServer:包含服务器的核心功能与混合(mix-in)类 ...
 - java nio实现非阻塞Socket通信实例
		
服务器 package com.java.xiong.Net17; import java.io.IOException; import java.net.InetSocketAddress; imp ...
 - Python—网络通信编程之tcp非阻塞通信(socketserver)
		
服务端代码 import socketserver # 定义一个类 class MyServer(socketserver.BaseRequestHandler): # 如果handle方法出现报错, ...
 
随机推荐
- Android OpenGL 入门示例----绘制三角形和正方形
			
Android上对OpenGl的支持是无缝的,所以才有众多3D效果如此逼真的游戏,在Camera的一些流程中也有用到GLSurfaceView的情况.本文记录OpenGL在Android上的入门级示例 ...
 - CodeForces 719B Anatoly and Cockroaches 思维锻炼题
			
题目大意:有一排蟑螂,只有r和b两种颜色,你可以交换任意两只蟑螂的位置,或涂改一个蟑螂的颜色,使其变成r和b交互排列的形式.问做少的操作次数. 题目思路:更改后的队列只有两种形式:长度为n以r开头:长 ...
 - SEO策略与细节:细节决定成败
			
昨天展开seo探讨会.听了一场医疗界seo大神的讲座.收益匪浅今天讲他的演讲内容整理出来与大家分享.希望对医疗界的seo带来些帮助.站长们一起成长! 一.首页 1.元标签设置 标题:上海癫痫病医院哪家 ...
 - FTP: Configuring server users..
			
4 points to create a user to uploade to ftproot.. this user must be an administrator, and be able to ...
 - php   生成  验证码的例子
			
/** +---------------------------------------------------------- * 生成随机字符串 CuPlayer.com 酷播 +-------- ...
 - C语言版的16进制与字符串互转函数
			
http://www.cnblogs.com/nio-nio/p/3309367.html /* // C prototype : void StrToHex(BYTE *pbDest, BYTE * ...
 - POJ 1845 Sumdiv (整数拆分+等比快速求和)
			
当我们拆分完数据以后, A^B的所有约数之和为: sum = [1+p1+p1^2+...+p1^(a1*B)] * [1+p2+p2^2+...+p2^(a2*B)] *...*[1+pn+pn^2 ...
 - POJ 2635 The Embarrassed Cryptographer(大数求余)
			
题意:给出一个大数,这个大数由两个素数相乘得到,让我们判断是否其中一个素数比L要小,如果两个都小,输出较小的那个. 分析:大数求余的方法:针对题目中的样例,143 11,我们可以这样算,1 % 11 ...
 - java 设计模式之单利模式以及代理模式(静态)
			
1:单利模式: public class Singleton { private static Singleton uniqueInstance = null; private Singleton() ...
 - plsql找外键约束关联的表的方法
			
直接Ctrl + 鼠标左键 表名 就可以找到参照表(关联表)的名称 下面的是复杂的方法 这个就是关联的表 这里右键查看 可以查看到参照的表