java中bio_JAVA的BIO

[TOC]

### 一、BIO简介

同步并阻塞IO(传统IO模型),服务器实现模式为一个连接一个线程,即客户端有连接请求时服务器端需要启动一个线程进行处理,这样就会导致如果这个连接不做任何事情,只是在等待客户端的消息那么就会造成浪费

![image-20210115192810412](http://cdn.noteblogs.cn/image-20210115192810412.png)

### 二、BIO服务器端

```java

public class BIOServer {

private static int port = 8089;

public static void main(String[] args) throws IOException {

ExecutorService executorService = Executors.newCachedThreadPool(); //多线程

ServerSocket serverSocket = new ServerSocket(port);

while(true){

System.out.println("等待用户连接");

Socket accept = serverSocket.accept(); //堵塞

System.out.println("连接到一个客户端");

executorService.submit(() -> {handle(accept);});

}

}

private static void handle(Socket socket) {

InputStream inputStream = null;

try {

inputStream = socket.getInputStream();

byte[] bytes = new byte[1024];

while(true){

System.out.println("read");

int i = inputStream.read(bytes); //堵塞

if(i != -1){

System.out.println(new String(bytes));

}

}

} catch (IOException e) {

e.printStackTrace();

}finally {

try {

socket.close();

} catch (IOException e) {

e.printStackTrace();

}

}

}

}

```

运行上面代码,使用telnet客户端工具连接 telnet 127.0.0.1 8089,然后按ctrl + ]可以进行字符串的输入

![image-20210121193333303](http://cdn.noteblogs.cn/image-20210121193333303.png)

因为上面代码使用了多线程,所以可以同时连接多个客户端,但是如果客户端不发数据那么该资源是被浪费掉了,所以BIO适合于连接数目小的应用,而后面的NIO则可以解决这个问题

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值