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 ,如需转载请自行联系原作者
相关文章
|
7月前
|
JSON 网络协议 安全
【Java】(10)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
350 2
|
7月前
|
JSON 网络协议 安全
【Java基础】(1)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
343 2
|
7月前
|
机器学习/深度学习 分布式计算 Java
Java与图神经网络:构建企业级知识图谱与智能推理系统
图神经网络(GNN)作为处理非欧几里得数据的前沿技术,正成为企业知识管理和智能推理的核心引擎。本文深入探讨如何在Java生态中构建基于GNN的知识图谱系统,涵盖从图数据建模、GNN模型集成、分布式图计算到实时推理的全流程。通过具体的代码实现和架构设计,展示如何将先进的图神经网络技术融入传统Java企业应用,为构建下一代智能决策系统提供完整解决方案。
610 0
|
9月前
|
JSON 移动开发 网络协议
Java网络编程:Socket通信与HTTP客户端
本文全面讲解Java网络编程,涵盖TCP与UDP协议区别、Socket编程、HTTP客户端开发及实战案例,助你掌握实时通信、文件传输、聊天应用等场景,附性能优化与面试高频问题解析。
|
存储 网络协议 安全
Java网络编程,多线程,IO流综合小项目一一ChatBoxes
**项目介绍**:本项目实现了一个基于TCP协议的C/S架构控制台聊天室,支持局域网内多客户端同时聊天。用户需注册并登录,用户名唯一,密码格式为字母开头加纯数字。登录后可实时聊天,服务端负责验证用户信息并转发消息。 **项目亮点**: - **C/S架构**:客户端与服务端通过TCP连接通信。 - **多线程**:采用多线程处理多个客户端的并发请求,确保实时交互。 - **IO流**:使用BufferedReader和BufferedWriter进行数据传输,确保高效稳定的通信。 - **线程安全**:通过同步代码块和锁机制保证共享数据的安全性。
597 23
|
Java
java中I/O流之字节流和字符流学习总结(下)
java中I/O流之字节流和字符流学习总结(下)
201 0
java中I/O流之字节流和字符流学习总结(下)
|
移动开发 Java 数据库
java中I/O流之字节流和字符流学习总结(上)
java中I/O流之字节流和字符流学习总结(上)
235 0
java中I/O流之字节流和字符流学习总结(上)
|
移动开发 Java
Java I/O学习(附实例和详解)
版权声明:本文为博主原创文章,转载注明出处http://blog.csdn.net/u013142781 目录(?)[+] 一、Java I/O类结构以及流的基本概念 在阅读Java I/O的实例之前我们必须清楚一些概念,我们先看看Java I/O的类结构图: Java I/O主要以流的形式进行读写数据。
2660 0
Java I/O学习(附实例和详解)
<p>原文地址:<a target="_blank" href="http://blog.csdn.net/u013142781/article/details/50814649">http://blog.csdn.net/u013142781/article/details/50814649</a></p> <p></p> <h2 id="一java-io类结构以及流的基本概念" s
1389 0
|
8月前
|
数据采集 存储 弹性计算
高并发Java爬虫的瓶颈分析与动态线程优化方案
高并发Java爬虫的瓶颈分析与动态线程优化方案