• Java BIO


    Java BIO  应用实例

    1. 实例说明:

      1)   使用 BIO 模型编写一个服务器端,监听 6666 端口,当有客户端连接时,就启动一个线程与之通讯。

      2)   要求使用线程池机制改善,可以连接多个客户端.

      3)   服务器端可以接收客户端发送的数据(telnet  方式即可)。

      4)   代码演示

    telnet连接发送数据:  {cmd -> telnet 127.0.0.1 6666 -> ctrl+] -> send xxx}

    package com.example.netty.bio;
    
    import java.io.IOException;
    import java.io.InputStream;
    import java.net.ServerSocket;
    import java.net.Socket;
    import java.util.concurrent.ExecutorService;
    import java.util.concurrent.Executors;
    
    /**
     * 线程池机制:
     * 思路:
     * 1.创建一个线程池;
     * 2.有客户端连接就创建一个线程,与之通讯(单独写一个方法)
     */
    public class BIOServer {
        public static void main(String[] args) throws IOException {
            ExecutorService newCachedThreadPool = Executors.newCachedThreadPool();
            final ServerSocket serverSocket = new ServerSocket(6666);
            System.out.println("服务器启动了,线程ID:" + Thread.currentThread().getId() + " 线程名称:" + Thread.currentThread().getName());
            while (true) {
                System.out.println("线程:" + Thread.currentThread().getName() + "等待连接...");
                Socket socket = serverSocket.accept();
                System.out.println("连接到客户端,线程ID:" + Thread.currentThread().getId() + " 线程名称:" + Thread.currentThread().getName());
                newCachedThreadPool.execute(() -> {
                    handle(socket);
                });
            }
        }
    
        //编写一个handle与客户端通讯
        private static void handle(Socket socket) {
            try {
                byte[] bytes = new byte[1024];
                InputStream inputStream = socket.getInputStream();
                while (true) {
                    System.out.println("线程:" + Thread.currentThread().getName() + "等待read...");
                    int read = inputStream.read(bytes);
                    if (read != -1) {
                        System.out.println("读取到数据,线程ID:" + Thread.currentThread().getId() + " 线程名称:" + Thread.currentThread().getName());
                        System.out.println("客户端发送的数据:" + new String(bytes, 0, read));
                    } else {
                        break;
                    }
                }
            } catch (Exception e) {
                e.printStackTrace();
            } finally {
                try {
                    System.out.println("关闭与client的连接");
                    socket.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }
    
    }
    View Code
  • 相关阅读:
    简单的BMCP位图图片压缩算法
    163相册验证码图片的识别手记之二 识别
    认父亲的DbParameter!!
    文件同步精灵(初版)
    163相册验证码图片的识别手记之一 去除干扰
    C#中WebService里的回车符"\r"丢失问题
    PHP 杂谈《重构改善既有代码的设计》之二 对象之间搬移特性
    PHP5计划任务离线功能的原理
    (转)程序员疫苗:代码注入
    window7环境,不安装Oracle,使用PL/SQL Developer结合oracle精简客户端,管理Oracle数据库
  • 原文地址:https://www.cnblogs.com/luliang888/p/12401268.html
Copyright © 2020-2023  润新知