使用线程池改进Bio

Server端:

package com.huayang.fakeasyncio;

import com.huayang.Bio.ServerHandler;

import java.io.IOException;
import java.net.ServerSocket;
import java.net.Socket;

public class Server {

public static void main(String[] args) {
ServerSocket serverSocket = null;
try {
serverSocket = new ServerSocket(10001);
System.out.println("server start in port 10001");
Socket socket = null;
ServerThreadExcutorPool singleExcutor = new ServerThreadExcutorPool(50, 1000);
while (true) {
socket = serverSocket.accept();
singleExcutor.execute(new ServerHandler(socket));
}
} catch (IOException e) {
e.printStackTrace();
} finally {
if (null != serverSocket) {
try {
serverSocket.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
}


线程池:

package com.huayang.fakeasyncio;

import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;

public class ServerThreadExcutorPool {
private ExecutorService executorService;

public ServerThreadExcutorPool(int maxPoolSize, int queneSize) {
executorService = new ThreadPoolExecutor(Runtime.getRuntime().availableProcessors(),
maxPoolSize, 120L, TimeUnit.SECONDS,
new ArrayBlockingQueue<Runnable>(queneSize));
}
public void execute(java.lang.Runnable task) {
executorService.execute(task);
}
}


client端以及task沿用上一篇
改进点:
由于线程池和消息队列都是有界的,无论客户端并发连接数有多大,都不会导致线程数过多或者线程栈溢出
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个简单的Java BIO使用例子,实现了一个简单的通信服务端和客户端: 服务端代码: ```java import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; import java.net.ServerSocket; import java.net.Socket; public class Server { public static void main(String[] args) throws IOException { ServerSocket serverSocket = new ServerSocket(8888); System.out.println("Server started, listening on port 8888..."); while (true) { Socket socket = serverSocket.accept(); System.out.println("Client " + socket.getRemoteSocketAddress() + " connected"); InputStream is = socket.getInputStream(); OutputStream os = socket.getOutputStream(); try { byte[] buffer = new byte[1024]; int n; while ((n = is.read(buffer)) != -1) { String s = new String(buffer, 0, n, "UTF-8"); System.out.println("Server received: " + s); os.write(("Server received: " + s).getBytes("UTF-8")); } } catch (IOException e) { e.printStackTrace(); System.out.println("Client " + socket.getRemoteSocketAddress() + " disconnected"); } finally { socket.close(); } } } } ``` 客户端代码: ```java import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; import java.net.Socket; import java.util.Scanner; public class Client { public static void main(String[] args) throws IOException { Socket socket = new Socket("localhost", 8888); System.out.println("Connected to server " + socket.getRemoteSocketAddress()); InputStream is = socket.getInputStream(); OutputStream os = socket.getOutputStream(); Scanner scanner = new Scanner(System.in); while (true) { System.out.print("Enter message (type 'exit' to quit): "); String line = scanner.nextLine(); if ("exit".equals(line)) { break; } os.write(line.getBytes("UTF-8")); byte[] buffer = new byte[1024]; int n = is.read(buffer); String s = new String(buffer, 0, n, "UTF-8"); System.out.println("Client received: " + s); } socket.close(); } } ``` 这个例子实现了一个简单的回显服务器,客户端可以向服务器发送消息,服务器接收到消息后回复给客户端。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值