多線程Java Socket編程示例
這篇做為學(xué)習(xí)孫衛(wèi)琴<<Java網(wǎng)絡(luò)編程精解>>的學(xué)習(xí)筆記吧.其中采用Java 5的ExecutorService來(lái)進(jìn)行線程池的方式實(shí)現(xiàn)多線程,模擬客戶端多用戶向同一服務(wù)器端發(fā)送請(qǐng)求.
1.服務(wù)端
package sterning;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.PrintWriter;
import java.net.*;
import java.util.concurrent.*;

public class MultiThreadServer {
private int port=8821;
private ServerSocket serverSocket;
private ExecutorService executorService;//線程池
private final int POOL_SIZE=10;//單個(gè)CPU線程池大小
public MultiThreadServer() throws IOException{
serverSocket=new ServerSocket(port);
//Runtime的availableProcessor()方法返回當(dāng)前系統(tǒng)的CPU數(shù)目.
executorService=Executors.newFixedThreadPool(Runtime.getRuntime().availableProcessors()*POOL_SIZE);
System.out.println("服務(wù)器啟動(dòng)");
}
public void service(){
while(true){
Socket socket=null;
try {
//接收客戶連接,只要客戶進(jìn)行了連接,就會(huì)觸發(fā)accept();從而建立連接
socket=serverSocket.accept();
executorService.execute(new Handler(socket));
} catch (Exception e) {
e.printStackTrace();
}
}
}
public static void main(String[] args) throws IOException {
new MultiThreadServer().service();
}

}

class Handler implements Runnable{
private Socket socket;
public Handler(Socket socket){
this.socket=socket;
}
private PrintWriter getWriter(Socket socket) throws IOException{
OutputStream socketOut=socket.getOutputStream();
return new PrintWriter(socketOut,true);
}
private BufferedReader getReader(Socket socket) throws IOException{
InputStream socketIn=socket.getInputStream();
return new BufferedReader(new InputStreamReader(socketIn));
}
public String echo(String msg){
return "echo:"+msg;
}
public void run(){
try {
System.out.println("New connection accepted "+socket.getInetAddress()+":"+socket.getPort());
BufferedReader br=getReader(socket);
PrintWriter pw=getWriter(socket);
String msg=null;
while((msg=br.readLine())!=null){
System.out.println(msg);
pw.println(echo(msg));
if(msg.equals("bye"))
break;
}
} catch (IOException e) {
e.printStackTrace();
}finally{
try {
if(socket!=null)
socket.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
2.客戶端
package sterning;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.net.Socket;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

public class MultiThreadClient {
public static void main(String[] args) {
int numTasks = 10;
ExecutorService exec = Executors.newCachedThreadPool();

for (int i = 0; i < numTasks; i++) {
exec.execute(createTask(i));
}

}

// 定義一個(gè)簡(jiǎn)單的任務(wù)
private static Runnable createTask(final int taskID) {
return new Runnable() {
private Socket socket = null;
private int port=8821;

public void run() {
System.out.println("Task " + taskID + ":start");
try {
socket = new Socket("localhost", port);
// 發(fā)送關(guān)閉命令
OutputStream socketOut = socket.getOutputStream();
socketOut.write("shutdown\r\n".getBytes());

// 接收服務(wù)器的反饋
BufferedReader br = new BufferedReader(
new InputStreamReader(socket.getInputStream()));
String msg = null;
while ((msg = br.readLine()) != null)
System.out.println(msg);
} catch (IOException e) {
e.printStackTrace();
}
}

};
}
}
從而實(shí)現(xiàn)了多個(gè)客戶端向服務(wù)器端發(fā)送請(qǐng)求,服務(wù)器端采用多線程的方式來(lái)處理的情況.再結(jié)合我之前的例子---Java基于Socket文件傳輸示例,就可以實(shí)現(xiàn)多線程文件的傳輸了
這篇做為學(xué)習(xí)孫衛(wèi)琴<<Java網(wǎng)絡(luò)編程精解>>的學(xué)習(xí)筆記吧.其中采用Java 5的ExecutorService來(lái)進(jìn)行線程池的方式實(shí)現(xiàn)多線程,模擬客戶端多用戶向同一服務(wù)器端發(fā)送請(qǐng)求.
1.服務(wù)端




















































































2.客戶端




















































從而實(shí)現(xiàn)了多個(gè)客戶端向服務(wù)器端發(fā)送請(qǐng)求,服務(wù)器端采用多線程的方式來(lái)處理的情況.再結(jié)合我之前的例子---Java基于Socket文件傳輸示例,就可以實(shí)現(xiàn)多線程文件的傳輸了