Java网络编程(32):一个非阻塞I/O的例子
2011-08-04 13:58
363 查看
原文地址:/article/4124606.html
为了使读者更好地理解非阻塞I/O,本节给出了一个简单的例子用来演示如何将非阻塞I/O应用到网络程序中。读者可以先不必管这个例子的具体细节。因为这个例子的主要目的并不是讲解非阻塞I/O的使用,而是先让读者对非阻塞I/O有一个笼统的感性认识。在看完这个例子后,读者可能会有很多疑问,在本章后面的部分将会逐渐揭开这些迷团。这个例子的主要功能是访问新浪网,并将新浪网的首页在控制台上输出。
package test;
import java.net.*;
import java.nio.*;
import java.nio.channels.*;
import java.io.*;
public class FirstNonBlockingIO
{
public static void main(String[] args) throws Exception
{
SocketAddress remote = new InetSocketAddress("www.sina.com.cn", 80);
SocketChannel channel = SocketChannel.open(remote);
String request = "GET / HTTP/1.1\r\n" +
"Host:www.sina.com.cn\r\n" +
"Connection:close\r\n\r\n";
ByteBuffer header = ByteBuffer.wrap(request.getBytes());
channel.write(header);
ByteBuffer buffer = ByteBuffer.allocate(1024);
WritableByteChannel out = Channels.newChannel(System.out);
while (channel.read(buffer) != -1)
{
buffer.flip();
out.write(buffer);
buffer.clear();
}
channel.close();
}
}
测试
执行如下命令:
java test.FirstNonBlockingIO > sina.txt
打开sina.txt后,会看到如下的文件内容:
HTTP/1.0 200 OK
Date: Sun, 01 Apr 2007 06:53:50 GMT
Server: Apache/2.0.58 (Unix)
Last-Modified: Sun, 01 Apr 2007 06:50:47 GMT
Connection: close
...
...
</body>
</html>
由于新浪网的主页内容太多,因此,为了方便查看程序运行结果,使用输出重定向符“>”将本该输出到控制台的内容输出到sina.txt文件中。从例程7-1可以看出,主要有三点和同步I/O存在差异。
1. 连接服务器(第013行)。使用SocketChannel类,而不是Socket类。
2. 向服务端写数据(第018行)。 使用SocketChannel类中的write方法,而不是OutputStream。
3. 从服务端读数据(第021行)。使用SocketChannel类中的read方法,而不是InputStream。
除了上面的三点外,在本例中还使用了缓冲区来处理输入输出数据。因此,通道(Channels)和缓冲区(Buffers)是学习非阻塞I/O之前必须掌握的知识。在下面的文章等将详细讲解这两部分的内容。
为了使读者更好地理解非阻塞I/O,本节给出了一个简单的例子用来演示如何将非阻塞I/O应用到网络程序中。读者可以先不必管这个例子的具体细节。因为这个例子的主要目的并不是讲解非阻塞I/O的使用,而是先让读者对非阻塞I/O有一个笼统的感性认识。在看完这个例子后,读者可能会有很多疑问,在本章后面的部分将会逐渐揭开这些迷团。这个例子的主要功能是访问新浪网,并将新浪网的首页在控制台上输出。
package test;
import java.net.*;
import java.nio.*;
import java.nio.channels.*;
import java.io.*;
public class FirstNonBlockingIO
{
public static void main(String[] args) throws Exception
{
SocketAddress remote = new InetSocketAddress("www.sina.com.cn", 80);
SocketChannel channel = SocketChannel.open(remote);
String request = "GET / HTTP/1.1\r\n" +
"Host:www.sina.com.cn\r\n" +
"Connection:close\r\n\r\n";
ByteBuffer header = ByteBuffer.wrap(request.getBytes());
channel.write(header);
ByteBuffer buffer = ByteBuffer.allocate(1024);
WritableByteChannel out = Channels.newChannel(System.out);
while (channel.read(buffer) != -1)
{
buffer.flip();
out.write(buffer);
buffer.clear();
}
channel.close();
}
}
测试
执行如下命令:
java test.FirstNonBlockingIO > sina.txt
打开sina.txt后,会看到如下的文件内容:
HTTP/1.0 200 OK
Date: Sun, 01 Apr 2007 06:53:50 GMT
Server: Apache/2.0.58 (Unix)
Last-Modified: Sun, 01 Apr 2007 06:50:47 GMT
Connection: close
...
...
</body>
</html>
由于新浪网的主页内容太多,因此,为了方便查看程序运行结果,使用输出重定向符“>”将本该输出到控制台的内容输出到sina.txt文件中。从例程7-1可以看出,主要有三点和同步I/O存在差异。
1. 连接服务器(第013行)。使用SocketChannel类,而不是Socket类。
2. 向服务端写数据(第018行)。 使用SocketChannel类中的write方法,而不是OutputStream。
3. 从服务端读数据(第021行)。使用SocketChannel类中的read方法,而不是InputStream。
除了上面的三点外,在本例中还使用了缓冲区来处理输入输出数据。因此,通道(Channels)和缓冲区(Buffers)是学习非阻塞I/O之前必须掌握的知识。在下面的文章等将详细讲解这两部分的内容。
相关文章推荐
- Java网络编程从入门到精通(32):一个非阻塞I/O的例子
- java.NIO网络编程很不错的一个例子
- 一个java网络编程Socket的例子,实现Server与Client聊天
- java网络编程实现一个聊天程序
- 关于Java的RMI编程的一个简单的例子
- Java网络编程基础 1 建立一个提供当前时间字符串的ServerSocket
- Java网络编程 - 非阻塞IO模型
- Java网络编程 - 同步阻塞IO模型
- JAVA_ 网络编程,写一个可以上传文件的服务器和客户端
- Java 多线程编程之五:一个理解 wait() 与 notify() 的例子
- Java网络编程三:Java NIO-非阻塞通信
- Java 多线程编程之五:一个理解 wait() 与 notify() 的例子
- 一个用于网络编程封包解包的java类型转换类
- Java网络编程——使用NIO实现非阻塞Socket通信
- 非阻塞TCP套接字的要点 发表于 2015-04-22 | 分类于 网络编程 | 套接字的默认状态是阻塞的。如果一个套接字不能立即完成相应的调用,那么该线程就会被投入睡眠,等待相应的操
- [零基础学JAVA]Java SE应用部分-32.Java网络编程 推荐
- Java基础---Java---网络编程---TCP的传输、客户端和服务端的互访、建立一个文本转换器、编写一个聊天程序
- java网络编程(四)----异步非阻塞aio及proactor模型
- 【网络编程5】Java与Python套接字Socket通信的例子
- Java网络编程(31):非阻塞I/O简介