(转)Socket+线程池(ExecutorService)

服务端:

public class MultiServerPool {
private ServerSocket serverSocket;
private ExecutorService pool;// 线程池
private final int POOL_SIZE = 10;// 单个CPU线程池大小

public void service() {
try {
serverSocket = new ServerSocket(2046);
// Runtime的availableProcessor()方法返回当前系统的CPU数目.
pool = Executors.newFixedThreadPool(Runtime.getRuntime().
availableProcessors() * POOL_SIZE);
System.out.println("服务器启动...");

while (true) {
Socket socket = serverSocket.accept();

pool.execute(new Handler(socket));
}
} catch (IOException e) {
e.printStackTrace();
}
}

public static void main(String[] args) {
new MultiServerPool().service();
}

}

class Handler implements Runnable {

private Socket socket;
private BufferedReader is;
private PrintWriter os;

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

@Override
public void run() {
try {
is = new BufferedReader(new InputStreamReader(socket.getInputStream()));
os = new PrintWriter(socket.getOutputStream());

String msg = is.readLine();

if (msg.equals("1")) {
try {
Thread.sleep(5000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}

System.out.println("客户端说:" + msg);
os.println("服务端收到消息:" + msg);
os.flush();
} catch (IOException e) {
e.printStackTrace();
} finally {
try {
if (os != null) {
os.close();
}
if (is != null) {
is.close();
}
if (socket != null) {
socket.close();
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
}

客户端:

public class MultiClient {

private static Runnable service(final int i) {
return new Runnable() {
private Socket socket = null;
BufferedReader in = null;
PrintWriter out = null;

@Override
public void run() {
try {
socket = new Socket("localhost", 2046);

in = new BufferedReader(new InputStreamReader(socket.getInputStream()));
out = new PrintWriter(socket.getOutputStream());

out.println(i);
out.flush();
System.out.println(in.readLine());

} catch (UnknownHostException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}

};
}

public static void main(String[] args) {
Thread t1 = new Thread(service(1));
Thread t2 = new Thread(service(2));
t1.start();
t2.start();
}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值