Java 傳統的socket連接以及使用線程池連接


public class TestServer {

    public static void main(String[] args) {
        try {
            ServerSocket socket = new ServerSocket(11111);
            while (true) {
                //監聽連接
                Socket socket1 = socket.accept();
                //新建一條線程去處理數據
                new Thread(new TestServerHanlder(socket1)).start();
                //使用線程池的方式去做處理
                TestServerHandlerExcutePool pool = new TestServerHandlerExcutePool(100, 100);
                pool.execute(new TestServerHanlder(socket1));
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

 

public class TestServerHanlder implements Runnable {

    private Socket socket;

    public TestServerHanlder(Socket socket) {
        this.socket = socket;
    }

    public void run() {
        BufferedReader in = null;
        PrintWriter out = null;
        try {
            in = new BufferedReader(new InputStreamReader(this.socket.getInputStream()));
            out = new PrintWriter(this.socket.getOutputStream(), true);
            String body = null;
            while (true) {
                body = in.readLine();
                if (StringUtils.isBlank(body)) {
                    break;
                }
                System.out.println("this is a test");
            }
        } catch (Exception ex) {

        }


    }
}

  

public class TestServerHandlerExcutePool {

    private ExecutorService service = null;

    public TestServerHandlerExcutePool(int maxPoolSize, int queueSize) {
        service = new ThreadPoolExecutor(Runtime.getRuntime().availableProcessors(), maxPoolSize,
                120L, TimeUnit.SECONDS, new ArrayBlockingQueue<>(queueSize));
    }

    public void execute(Runnable task) {
        service.execute(task);
    }
}

傳統的io流是阻塞式的,假如多條線程請求同一個數據,會導致阻塞,如下圖api說明:

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM