java网络编程(一):java传统的阻塞IO以及多线程解决方案

本文介绍了Java传统的阻塞IO模型在Socket编程中的应用,通过一个实例展示了单线程如何处理多个客户端连接的问题,揭示了其在高并发场景下的效率低下。为解决这一问题,提出了引入多线程以及使用线程池的方案,但即便如此,由于基于blocking IO,仍存在性能瓶颈。后续将探讨更优的IO模型。
摘要由CSDN通过智能技术生成

最近在看一些IO模型相关的东西,被同步IO、异步IO、阻塞IO、非阻塞IO概念弄的有点晕,后面再慢慢学习和领悟。我们以socket IO编程为例子,我用的是JDK1.7.0_80,测试工具用的是SocketTest。我们先学习下最简单、最原始的IO模型,在《Unix网络编程卷》中被称为:blocking IO。



SingleThreadBlockingIO是我们用java socket编程实现的blocking IO。

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.net.ServerSocket;
import java.net.Socket;

public class SingleThreadBlockingIO {

	public static void main(String[] args) throws Exception{
		
		ServerSocket serverSocket = new ServerSocket(8888);
		
		while (true)
        {
			// 阻塞直到有客户端连接上
            Socket clientSocket = serverSocket.accept();
            try
            {
            	 process(clientSocket);
            }
            catch(Exception e)
            {
            	e.printStackTrace();
            	clientSocket.close();
            }
        }
	}
	
	private static void process( Socket clientSocket) throws Exception
	{
		System.out.println("client socket连接:" + clientSocket.getRemoteSocketAddress());
        BufferedReader in = new BufferedReader(new InputStreamReader(clientSocket.getInputStream()));
        BufferedWrit
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值