java BIO

目录

Java BIO基本介绍

Java BIO工作机制

传统的BIO编程实例回顾

1、BIO模式下发送和接收消息

2、BIO模式下多发和多收消息

3、BIO模式下接收多个客户端

伪异步I/O编程

基于BIO形式下的文件上传

Java BIO模式下的端口转发思想


Java BIO基本介绍

  • Java BIO就是传统的java io 编程,其相关的类和接口在java.io
  • BlO(blocking I/O):同步阻塞,服务器实现模式为一个连接一个线程,即客户端有连接请求时服务器就需要启动一个线程进行处理,如果这个连接不做任何事情会造成不必要的线程开销,可以通过线程池机制改善(实现多个客户连接服务器).

Java BIO工作机制

传统的BIO编程实例回顾

        网络编程的基本模型是Client/Server模型,也就是两个进程之间进行相互通信,其中服务端提供位置信(绑定IP地址和端口),客户端通过连接操作向服务端监听的端口地址发起连接请求,基于TCP协议下进行三次握手连接,连接成功后,双方通过网络套接字(Socket)进行通信。
        传统的同步阻塞模型开发中,服务端ServerSocket负责绑定IP地址,启动监听端口;客户端Socket负责发起连接操作。连接成功后,双方通过输入和输出流进行同步阻塞式通信。
        基于BIO模式下的通信,客户端-服务端是完全同步,完全耦合的。

1、BIO模式下发送和接收消息

服务端

/**
 * 服务端接受消息
 */
public class Server {
    public static void main(String[] args) {
        try {
            System.out.println("——服务端启动——");
            //定义一个ServerSocket对象进行服务端的端口注册
            ServerSocket ss = new ServerSocket(9999);
            //监听客户端的socket链接请求
            Socket socket = ss.accept();
            //从socket管道中得到一个字节输入流对象
            InputStream is = socket.getInputStream();
            //把字节输入流包装成一个缓冲字符输入流
            BufferedReader br = new BufferedReader(new InputStreamReader(is));
            String msg;
            if ((msg = br.readLine()) != null){
                System.out.println("服务端接收到:"+msg);
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

客户端

/**
 * 客户端发送消息
 */
public class Client {
    public static void main(String[] args) {
        try {
            //创建socket对象请求服务端的链接
            Socket socket = new Socket("127.0.0.1",9999);
            //从socket对象中获取一个字节输出流
            OutputStream os = socket.getOutputStream();
            //把字节输出流包装成一个打印流
            PrintStream ps = new PrintStream(os);
            ps.println("hello world!");
            ps.flush();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}
2、BIO模式下多发和多收消息

服务端

/**
 * 服务端可以反复的接收消息,
 */
public class Server {
    public static void main(String[] args) {
        try {
            System.out.println("——服务端启动——");
            //定义一个ServerSocket对象进行服务端的端口注册
            ServerSocket ss = new ServerSocket(9999);
            //监听客户端的socket链接请求
            Socket socket = ss.accept();
            //从socket管道中得到一个字节输入流对象
            InputStream is = socket.getInputStream();
            //把字节输入流包装成一个缓冲字符输入流
            BufferedReader br = new BufferedReader(new InputStreamReader(is));
            String msg;
            while ((msg = br.readLine()) != null){
                System.out.println("服务端接收到:"+msg);
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

客户端

/**
 * 客户端可以反复的发送消息。
 */
public class Client {
    public static void main(String[] args) {
        try {
            //创建socket对象请求服务端的链接
            Sock
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值