Java Socket和ServerSocket编程 NIO
来源:互联网 发布:tcp ip网络编程百度云 编辑:程序博客网 时间:2024/05/11 01:20
Socket server 和 client 通信流程图:
服务端代码:
serverSocket = new ServerSocket(); serverSocket.setReuseAddress(true); serverSocket.bind(new InetSocketAddress(port)); socket = serverSocket.accept(); socket.setSoTimeout(timeOut); //表示接收数据时的等待超时数据, 此方法必须在接收数据之前执行才有效. 此外, 当输入流的 read()方法抛出 SocketTimeoutException后, Socket仍然是连接的, 可以尝试再次读数据, 单位为毫秒, 它的默认值为 0(表示会无限等待, 永远不会超时) socket.setKeepAlive(false); //表示对于长时间处于空闲状态的Socket, 是否要自动把它关闭 in = new BufferedReader(new InputStreamReader(socket.getInputStream())); if (in.ready()) { //流准备好了做处理 } in.close()
客户端代码:发信息
socketclient = new Socket(serverip, port); socketclient.setSoTimeout(0); socketclient.setKeepAlive(false); os = new BufferedOutputStream(socketclient.getOutputStream()); os.write(information); os.flush(); os.close(); Thread.sleep(3000);
Socket通道
Java NIO中的SocketChannel是一个连接到TCP网络套接字的通道。可以通过以下2种方式创建SocketChannel:
打开一个SocketChannel并连接到互联网上的某台服务器。
一个新连接到达ServerSocketChannel时,会创建一个SocketChannel。
非阻塞模式
可以设置 SocketChannel 为非阻塞模式(non-blocking mode).设置之后,就可以在异步模式下调用connect(), read() 和write()了。
connect()
如果SocketChannel在非阻塞模式下,此时调用connect(),该方法可能在连接建立之前就返回了。为了确定连接是否建立,可以调用finishConnect()的方法。像这样:
socketChannel.configureBlocking(false); socketChannel.connect(new InetSocketAddress("http://jenkov.com", 80)); while(! socketChannel.finishConnect() ){ //wait, or do something else... }
write()
非阻塞模式下,write()方法在尚未写出任何内容时可能就返回了。所以需要在循环中调用write()。前面已经有例子了,这里就不赘述了。
read()
非阻塞模式下,read()方法在尚未读取到任何数据时可能就返回了。所以需要关注它的int返回值,它会告诉你读取了多少字节。
非阻塞模式与选择器
非阻塞模式与选择器搭配会工作的更好,通过将一或多个SocketChannel注册到Selector,可以询问选择器哪个通道已经准备好了读取,写入等。Selector与SocketChannel的搭配使用会在后面详讲。
ServerSocket 通道
Java NIO中的 ServerSocketChannel 是一个可以监听新进来的TCP连接的通道,就像标准IO中的ServerSocket一样。ServerSocketChannel类在 java.nio.channels包中。
非阻塞模式
ServerSocketChannel可以设置成非阻塞模式。在非阻塞模式下,accept() 方法会立刻返回,如果还没有新进来的连接,返回的将是null。 因此,需要检查返回的SocketChannel是否是null。如:
ServerSocketChannel serverSocketChannel = ServerSocketChannel.open(); serverSocketChannel.socket().bind(new InetSocketAddress(9999)); serverSocketChannel.configureBlocking(false); while(true){ SocketChannel socketChannel = serverSocketChannel.accept(); if(socketChannel != null){ //do something with socketChannel... } }
scoket保持心跳长连接代码见附件!
参考文章:
http://shihuan830619.iteye.com/blog/2041774
java NIO系列教程
http://www.iteye.com/magazines/132-Java-NIO
- Java Socket和ServerSocket编程 NIO
- Java网络编程(ServerSocket和Socket)
- JAVA: Socket和ServerSocket网络编程
- java网络编程:Socket和ServerSocket类
- java Socket和ServerSocket多线程编程
- Java Socket和ServerSocket
- [Java]Socket和ServerSocket
- ServerSocket和Socket编程案例
- [Java]Socket和ServerSocket学习
- Java Socket 编程 Socket与ServerSocket
- java socket/Serversocket编程详解(中/英文)
- java socket/Serversocket编程详解(中/英)
- java 网络编程类 DatagramSocket,ServerSocket,Socket
- java socket/Serversocket编程详解(中/英文)
- 【Java学习笔记】39:简易Socket编程(基于java.net下的Socket和ServerSocket)
- [Java]Socket和ServerSocket学习笔记
- java第二十四节-socket和serversocket
- [Java]Socket和ServerSocket学习笔记
- redis队列处理文件并发(日志处理)
- ActiveMQ消息中间件Producer和Consumer
- 用户浏览器禁用了cookie,SessionID如何传递
- java和javascript双引号嵌套的问题
- LLD3学习笔记(2) hello world
- Java Socket和ServerSocket编程 NIO
- anroid sqlite数据库操作框架
- Callable与Runable接口 submit与execute区别
- java concurrent包自带线程池和队列详细讲解
- ActiveMQ session.close与session.commit的区别
- ActiveMQ消息传送模型
- ActiveMQ BrokeUrl的配置和消息持久化配置
- Linux vi下常用实用命令
- Linux下执行Java服务程序