Java网络编程从入门到精通(32):一个非阻塞I/O的例子[Java编程]
本文“Java网络编程从入门到精通(32):一个非阻塞I/O的例子[Java编程]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
为了使读者更好地理解非阻塞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编程]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
本文地址: | 与您的QQ/BBS好友分享! |