Java中IO模型之BIO(同步阻塞模型)

Java中的BIO模型在JDK1.4前被广泛使用,它在服务端每接收到一个客户端连接时需要创建新线程进行处理,造成同步阻塞。BIO编程流程包括服务端的ServerSocket实例创建、绑定端口、监听客户端连接,以及客户端的Socket连接、读写操作。由于accept、read/write、connect方法可能导致阻塞,因此在高并发场景下,通常结合多线程处理多个客户端请求,但线程资源限制了其并发处理能力,这促使了NIO模型的出现。
摘要由CSDN通过智能技术生成

Java中IO模型之BIO(同步阻塞模型)

BIO:同步阻塞模型

在JDK1.4之前,建立网络通信采用的BIO模型
需要现在服务器启动一个ServerSocket,然后客户端启动一个Socket来对服务端进行连接,默认的情况下服务端需要对每一个请求建立一个线程等待处理,客户端发送请求后,需要等待服务端是否有相应的线程来处理客户端的连接,如果没有线程则会一致等待或者拒绝请求,如果有的话,客户端会等待线程来处理客户端请求

在了解BIO模型之前先让我们回顾一下Socket通信流程
在这里插入图片描述

基于BIO的编程

通过网络通信模拟echo命令的实现

服务端编程:

ServerSocket ssocket = null;
        try {
   
            //创建ServerSocket实例
            ssocket = new ServerSocket();
            //绑定端口
            ssocket.bind(new InetSocketAddress(9999));
            System.out.println("服务端已经启动...");

            //进行监听,等待客户端的连接
            Socket socket = ssocket.accept();
            System.out.println("客户端:"+socket.getRemoteSocketAddress()+"连接上");

            //进行读写操作
            BufferedReader reader = new BufferedReader(new InputStreamReader(socket.getInputStream()));
            String msg = reader.readLine();
            System.out.println("客户端:"+socket.getRemoteSocketAddress()+"发送消息:"+msg);
            //回复客户端消息
            OutputStream write = socket.getOutputStream();
            write.write(("echo:"
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值