Java网络编程从入门到精通(32):一个非阻塞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之前必须掌握的知识。在下面的文章等将详细讲解这两部分的内容。





 本文转自 androidguy 51CTO博客,原文链接:http://blog.51cto.com/androidguy/214333 ,如需转载请自行联系原作者
相关文章
|
存储 缓存 Oracle
Java I/O流面试之道
NIO的出现在于提高IO的速度,它相比传统的输入/输出流速度更快。NIO通过管道Channel和缓冲器Buffer来处理数据,可以把管道当成一个矿藏,缓冲器就是矿藏里的卡车。程序通过管道里的缓冲器进行数据交互,而不直接处理数据。程序要么从缓冲器获取数据,要么输入数据到缓冲器。
196 2
Java I/O流面试之道
|
Web App开发 网络协议 安全
网络编程懒人入门(十六):手把手教你使用网络编程抓包神器Wireshark
Wireshark是一款开源和跨平台的抓包工具。它通过调用操作系统底层的API,直接捕获网卡上的数据包,因此捕获的数据包详细、功能强大。但Wireshark本身稍显复杂,本文将以用抓包实例,手把手带你一步步用好Wireshark,并真正理解抓到的数据包的各项含义。
5471 2
|
存储 缓存 监控
Docker容器性能调优的关键技巧,涵盖CPU、内存、网络及磁盘I/O的优化策略,结合实战案例,旨在帮助读者有效提升Docker容器的性能与稳定性。
本文介绍了Docker容器性能调优的关键技巧,涵盖CPU、内存、网络及磁盘I/O的优化策略,结合实战案例,旨在帮助读者有效提升Docker容器的性能与稳定性。
1368 8
|
域名解析 网络协议 应用服务中间件
网络编程入门如此简单(四):一文搞懂localhost和127.0.0.1
本文将以网络编程入门者视角,言简意赅地为你请清楚localhost和127.0.0.1的关系及区别等。
809 2
网络编程入门如此简单(四):一文搞懂localhost和127.0.0.1
|
消息中间件 编解码 网络协议
Netty从入门到精通:高性能网络编程的进阶之路
【11月更文挑战第17天】Netty是一个基于Java NIO(Non-blocking I/O)的高性能、异步事件驱动的网络应用框架。使用Netty,开发者可以快速、高效地开发可扩展的网络服务器和客户端程序。本文将带您从Netty的背景、业务场景、功能点、解决问题的关键、底层原理实现,到编写一个详细的Java示例,全面了解Netty,帮助您从入门到精通。
2681 0
|
编解码 网络协议 Oracle
java网络编程入门以及项目实战
这篇文章是Java网络编程的入门教程,涵盖了网络编程的基础知识、IP地址、端口、通讯协议(TCP和UDP)的概念与区别,并提供了基于TCP和UDP的网络编程实例,包括远程聊天和文件传输程序的代码实现。
java网络编程入门以及项目实战
|
存储 缓存 Oracle
可能是最漂亮的Java I/O流详解
大家有什么思路吗?评论区一起讨论讨论。我需要使用 Java 逐行读取大约 5-6 GB 的大型文本文件。我怎样才能快速完成此操作?最高赞的回答是叫Peter Lawrey的老哥回答的。大家好,我是南哥。一个Java学习与进阶的领路人,今天指南的是Java I/O流,跟着南哥我们一起在Java之路上成长。本文收录在我开源的《Java学习进阶指南》中,涵盖了想要学习Java、成为更好的Java选手都在偷偷看的核心知识、面试重点。
256 1
可能是最漂亮的Java I/O流详解
|
数据采集 资源调度 JavaScript
Node.js 适合做高并发、I/O密集型项目、轻量级实时应用、前端构建工具、命令行工具以及网络爬虫和数据处理等项目
【8月更文挑战第4天】Node.js 适合做高并发、I/O密集型项目、轻量级实时应用、前端构建工具、命令行工具以及网络爬虫和数据处理等项目
428 5
|
Java Linux
Java演进问题之1:1线程模型对于I/O密集型任务如何解决
Java演进问题之1:1线程模型对于I/O密集型任务如何解决
176 1
|
网络协议 安全 Java
Java中的网络编程:Socket编程详解
Java中的网络编程:Socket编程详解
下一篇
开通oss服务