`
qing_gee
  • 浏览: 120845 次
  • 性别: Icon_minigender_1
  • 来自: 河南
社区版块
存档分类
最新评论

BIO

    博客分类:
  • Java
BIO 
阅读更多

前言:今天在学习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连接,发送查询命令,然后获取处理信息,然后进行资源回收。

 

总结:以上内容非常的简单,也易于理解,但是重新手写一下,加上写这篇博客,让我对此的印象会更加深刻。

0
0
分享到:
评论

相关推荐

    Bio-Rad CFX 定量PCR软件包

    Bio-Rad CFX定量PCR软件包是用于分析和管理Bio-Rad公司生产的CFX系列定量聚合酶链式反应(qPCR)数据的专业工具。在生物学研究领域,定量PCR是一种广泛使用的分子生物学技术,用于检测和量化特定DNA序列的拷贝数。这...

    openssl之BIO系列

    1. **创建BIO对象**:首先,我们需要创建特定类型的BIO对象,比如使用`BIO_new_file()`创建用于读写文件的BIO,或者使用`BIO_new_socket()`创建用于网络连接的BIO。 2. **链式操作**:多个BIO对象可以通过`BIO_push...

    openssl之BIO系列(01-25)

    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系列(01-25)(带目录)

    openssl之BIO系列之1---抽象的IO接口 1 openssl之BIO系列之2---BIO结构和BIO相关文件介绍 2 openssl之BIO系列之3---BIO的声明和释放等基本操作 5 openssl之BIO系列之4---BIO控制函数介绍 6 openssl之BIO系列之5---...

    关系抽取NYT数据集(BIO格式).zip

    总的来说,"关系抽取NYT数据集(BIO格式).zip"提供了丰富的语料资源,用于训练和评估关系抽取模型,特别是对于端到端模型来说,BIO格式的数据集使得模型可以直接处理,减少了数据预处理的复杂性,有利于推动NLP领域...

    Bio-Rad-Image-Lab-Software-6.1-Windows.zip

    Bio-Rad Image Lab Software是一款专为凝胶成像设计的专业软件,主要应用于生命科学领域,尤其是分子生物学实验中对DNA、RNA和蛋白质电泳凝胶的分析。此软件的6.1版本是针对Windows操作系统设计的,提供了强大的图像...

    BIO编程程序详细源代码

    标题"**BIO编程程序详细源代码**"指出,这是一个关于BIO( Blocking I/O,阻塞I/O)编程的资源,其中包含的是源代码,这意味着我们可以期待一系列用特定编程语言实现的BIO模式的示例。 描述中的"**BIO编程程序详细...

    基于java的BIO、NIO、AIO通讯模型代码实现

    Java作为一门广泛使用的开发语言,提供了多种I/O(Input/Output)通信模型,包括传统的阻塞I/O(BIO)、非阻塞I/O(NIO)以及异步I/O(AIO)。这些通信模型在不同的场景下有着各自的优势,理解和掌握它们对于优化...

    bio nio aio demo

    为了处理与外部世界的交互,Java提供了三种不同的I/O模型:BIO( Blocking I/O)、NIO(Non-blocking I/O)和AIO(Asynchronous I/O)。这些模型各有优缺点,适用于不同场景。下面我们将深入探讨这三种I/O模型,并...

    biojava-master

    《生物信息学与BioJava应用详解》 在生物信息学领域,BioJava是一个重要的开源工具,主要用于处理和分析生物学数据。这个名为“biojava-master”的压缩包包含了BioJava的源码以及相关的说明教程,为研究者和开发者...

    BIO API 生物认证标准

    ### BIO API 生物认证标准详解 #### 一、BIO API 概述 **BIO API**(生物特征应用编程接口)是一种开放的标准系统规范,它定义了一个应用程序接口(API),使得软件应用能够以一种通用的方式与广泛的生物识别技术...

    中文命名实体识别ner数据_resume_bio格式

    "中文命名实体识别ner数据_resume_bio格式"指的是一个专门针对中文NER的数据集,其数据格式遵循了BIO标注体系。 BIO标注体系是一种常见的用于NER任务的数据标注方式,全称为“Beginning Inside Outside”。在这个...

    Socket 之 BIO、NIO、Netty 简单实现

    在Java中,Socket通信涉及三种不同的模型:BIO(Blocking I/O)、NIO(Non-blocking I/O)和Netty,这些都是实现高并发、高性能网络服务的重要手段。 **1. Socket基础** Socket,通常被称为套接字,是网络通信的...

    关于bioJava(1)

    **生物信息学与bioJava简介** 在IT领域中,生物信息学是一门结合生物学、计算机科学和统计学的交叉学科,主要关注生命科学数据的处理和分析。在生物信息学中,开发各种软件工具和库是至关重要的,以便对基因序列、...

    BioJava(Java Library)指南

    BioJava是基于Java编程语言的一个开源生物信息学库,它为生物信息学家提供了一系列工具,用于处理和分析生物学数据。这个库涵盖了多个生物信息学领域,包括序列比对、基因组分析、蛋白质结构和功能预测等。下面我们...

    一站式学习Java网络编程 全面理解BIO:NIO:AIO1

    全面理解 Java 网络编程 - BIO、NIO、AIO 本课程旨在帮助学生全面理解 Java 网络编程中的 BIO、NIO、AIO 三剑客,掌握 RPC 编程的基础知识,并结合实战项目巩固所学。 一、网络编程三剑客 - BIO、NIO、AIO BIO...

    关于bioJava(2)

    关于“关于bioJava(2)”的这篇博客,作者可能主要讨论了开源生物信息学工具bioJava的第二部分内容。bioJava是一个用Java语言编写的库,主要用于处理生物学数据,如DNA序列、蛋白质序列等。它为生物信息学家提供了...

    data.rar BIO标注语料压缩包 下载可用

    "BIO标注语料压缩包"表明这个压缩包内包含的是用于自然语言处理(NLP)任务的语料库,采用了BIO(Begin Inside Outside)标注方法。BIO标注是一种常见的序列标注技术,主要用于实体识别(NER),它区分了实体的开始...

Global site tag (gtag.js) - Google Analytics