前言:今天在学习netty,看了BIO一章,内容也非常的简单,书中的例子也非常的简单,我又把其中的代码敲了一遍,感觉虽然简单,却受益匪浅,使我对阻塞同步式IO有了更清晰的认知。
经典的BIO例子,就是有一个服务端,负责监听客户端连接,然后为每一个客户端建立线程,处理客户端的请求,处理完成后销毁。
通过代码,我们就可以看出来,同步阻塞IO的弊端就是当客户端连接数膨胀后,系统的性能将会急剧下降,因为为每一个客户端开启一个线程,然后处理完成一个请求关闭,将会造成大量的内存垃圾。
package com.honzh.mwq.bio.server; import java.io.IOException; import java.net.ServerSocket; import java.net.Socket; import com.honzh.mwq.bio.server.handler.TimeServerHandler; public class TimeServer { public static void main(String[] args) { ServerSocket server = null; try { server = new ServerSocket(9901); System.out.println("server running at port: " + 9901); Socket socket = null; while (true) { socket = server.accept(); new Thread(new TimeServerHandler(socket)).start(); } } catch (IOException e) { e.printStackTrace(); } finally { if (server != null) { System.out.println("server close"); try { server.close(); } catch (IOException e) { e.printStackTrace(); } server = null; } } } }
上类创建一个server对象,等待客户端连接,在接收到客户端连接后,启动一个线程进行socket处理。
package com.honzh.mwq.bio.server.handler; import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.io.PrintWriter; import java.net.Socket; public class TimeServerHandler implements Runnable{ private Socket socket; private BufferedReader br = null; private PrintWriter pw = null; public TimeServerHandler(Socket socket) { this.socket = socket; } @Override public void run() { try { br = new BufferedReader(new InputStreamReader(socket.getInputStream())); pw = new PrintWriter(socket.getOutputStream(), true); while (true) { String order = br.readLine(); if (order != null) { System.out.println("the order is: " + order); if (order.equals("query")) { pw.println(System.currentTimeMillis()); } } else { break; } } } catch (Exception e) { if (br != null) { try { br.close(); } catch (IOException e1) { e1.printStackTrace(); } } if (pw != null) { pw.close(); pw = null; } if (socket != null) { try { socket.close(); socket = null; } catch (IOException e1) { e1.printStackTrace(); } } } } }
上类也非常的简单,线程启动后,获取客户端socket请求,如果请求到数据,则进行处理,等消息都处理完成后退出循环,然后等待资源回收。
package com.honzh.mwq.bio.client; import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.io.PrintWriter; import java.net.Socket; import java.net.UnknownHostException; public class TimeClient { public static void main(String[] args) { Socket socket = null; BufferedReader br = null; PrintWriter pw = null; try { socket = new Socket("127.0.0.1", 9901); br = new BufferedReader(new InputStreamReader(socket.getInputStream())); pw = new PrintWriter(socket.getOutputStream(), true); pw.println("query"); String result = br.readLine(); System.out.println("now time is: " + result); } catch (UnknownHostException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } finally { if (br != null) { try { br.close(); } catch (IOException e1) { e1.printStackTrace(); } } if (pw != null) { pw.close(); pw = null; } if (socket != null) { try { socket.close(); socket = null; } catch (IOException e1) { e1.printStackTrace(); } } } } }
上类启动客户端,进行socket连接,发送查询命令,然后获取处理信息,然后进行资源回收。
总结:以上内容非常的简单,也易于理解,但是重新手写一下,加上写这篇博客,让我对此的印象会更加深刻。
相关推荐
Bio-Rad CFX定量PCR软件包是用于分析和管理Bio-Rad公司生产的CFX系列定量聚合酶链式反应(qPCR)数据的专业工具。在生物学研究领域,定量PCR是一种广泛使用的分子生物学技术,用于检测和量化特定DNA序列的拷贝数。这...
1. **创建BIO对象**:首先,我们需要创建特定类型的BIO对象,比如使用`BIO_new_file()`创建用于读写文件的BIO,或者使用`BIO_new_socket()`创建用于网络连接的BIO。 2. **链式操作**:多个BIO对象可以通过`BIO_push...
openssl之BIO系列之1---抽象的IO接口 1 openssl之BIO系列之2---BIO结构和BIO相关文件介绍 2 openssl之BIO系列之3---BIO的声明和释放等基本操作 5 openssl之BIO系列之4---BIO控制函数介绍 6 openssl之BIO系列之5---...
openssl之BIO系列之1---抽象的IO接口 1 openssl之BIO系列之2---BIO结构和BIO相关文件介绍 2 openssl之BIO系列之3---BIO的声明和释放等基本操作 5 openssl之BIO系列之4---BIO控制函数介绍 6 openssl之BIO系列之5---...
Bio-Rad Image Lab Software是一款专为凝胶成像设计的专业软件,主要应用于生命科学领域,尤其是分子生物学实验中对DNA、RNA和蛋白质电泳凝胶的分析。此软件的6.1版本是针对Windows操作系统设计的,提供了强大的图像...
标题"**BIO编程程序详细源代码**"指出,这是一个关于BIO( Blocking I/O,阻塞I/O)编程的资源,其中包含的是源代码,这意味着我们可以期待一系列用特定编程语言实现的BIO模式的示例。 描述中的"**BIO编程程序详细...
Java作为一门广泛使用的开发语言,提供了多种I/O(Input/Output)通信模型,包括传统的阻塞I/O(BIO)、非阻塞I/O(NIO)以及异步I/O(AIO)。这些通信模型在不同的场景下有着各自的优势,理解和掌握它们对于优化...
为了处理与外部世界的交互,Java提供了三种不同的I/O模型:BIO( Blocking I/O)、NIO(Non-blocking I/O)和AIO(Asynchronous I/O)。这些模型各有优缺点,适用于不同场景。下面我们将深入探讨这三种I/O模型,并...
《生物信息学与BioJava应用详解》 在生物信息学领域,BioJava是一个重要的开源工具,主要用于处理和分析生物学数据。这个名为“biojava-master”的压缩包包含了BioJava的源码以及相关的说明教程,为研究者和开发者...
BioJava是基于Java编程语言的一个开源生物信息学库,它为生物信息学家提供了一系列工具,用于处理和分析生物学数据。这个库涵盖了多个生物信息学领域,包括序列比对、基因组分析、蛋白质结构和功能预测等。下面我们...
全面理解 Java 网络编程 - BIO、NIO、AIO 本课程旨在帮助学生全面理解 Java 网络编程中的 BIO、NIO、AIO 三剑客,掌握 RPC 编程的基础知识,并结合实战项目巩固所学。 一、网络编程三剑客 - BIO、NIO、AIO BIO...
### BIO API 生物认证标准详解 #### 一、BIO API 概述 **BIO API**(生物特征应用编程接口)是一种开放的标准系统规范,它定义了一个应用程序接口(API),使得软件应用能够以一种通用的方式与广泛的生物识别技术...
"中文命名实体识别ner数据_resume_bio格式"指的是一个专门针对中文NER的数据集,其数据格式遵循了BIO标注体系。 BIO标注体系是一种常见的用于NER任务的数据标注方式,全称为“Beginning Inside Outside”。在这个...
在Java中,Socket通信涉及三种不同的模型:BIO(Blocking I/O)、NIO(Non-blocking I/O)和Netty,这些都是实现高并发、高性能网络服务的重要手段。 **1. Socket基础** Socket,通常被称为套接字,是网络通信的...
**生物信息学与bioJava简介** 在IT领域中,生物信息学是一门结合生物学、计算机科学和统计学的交叉学科,主要关注生命科学数据的处理和分析。在生物信息学中,开发各种软件工具和库是至关重要的,以便对基因序列、...
《BIO 命名实体识别 NER语料集》是一个专门用于训练和评估命名实体识别(NER)模型的数据集。在自然语言处理领域,命名实体识别是一项关键任务,其目的是从文本中抽取出具有特定意义的实体,如人名、地名、组织机构...
关于“关于bioJava(2)”的这篇博客,作者可能主要讨论了开源生物信息学工具bioJava的第二部分内容。bioJava是一个用Java语言编写的库,主要用于处理生物学数据,如DNA序列、蛋白质序列等。它为生物信息学家提供了...
"BIO标注语料压缩包"表明这个压缩包内包含的是用于自然语言处理(NLP)任务的语料库,采用了BIO(Begin Inside Outside)标注方法。BIO标注是一种常见的序列标注技术,主要用于实体识别(NER),它区分了实体的开始...