java網路編程二:伺服器處理多個使用者請求的解決方案(返回多個使用者輸入的資訊)

來源:互聯網
上載者:User

1、用多個線程來同時為多個客戶提供服務,這是提高伺服器的並發效能的最常用的手段,那麼怎樣來為多個使用者提供服務呢?

     主要有三種方法:

     

2、為了更清楚理解伺服器到底是怎麼工作的,下面用第一種方式來處理多個使用者請求。如果想用第二、第三方式可以參考Touch的部落格:

java多線程總結五:線程池的原理及實現

 下面的樣本中用戶端輸入資訊,伺服器端回複相同的資訊,可以同時開啟多個用戶端,同時輸入資訊,原始碼如下:

伺服器端代碼:

package demo.net;import java.io.DataInputStream;import java.io.DataOutputStream;import java.io.IOException;import java.net.ServerSocket;import java.net.Socket;/** * 伺服器返回使用者輸入的資訊, 為多個使用者提供服務:為每個客戶分配一個背景工作執行緒 */public class ChatServers {private int port = 8189;// 預設伺服器連接埠public ChatServers() {}// 建立指定連接埠的伺服器public ChatServers(int port) {this.port = port;}public void service() {int i=0;try {// 建立伺服器串連,設定客戶串連請求隊列的長度ServerSocket server = new ServerSocket(port,3);while (true) {// 等待客戶串連Socket socket = server.accept();i++;System.out.println("第"+i+"個客戶串連成功!");new Thread(new ServerThread(socket)).start();}} catch (IOException e) {e.printStackTrace();}}public static void main(String[] args) {new ChatServers().service();}}class ServerThread implements Runnable {private Socket socket;public ServerThread(Socket socket) {this.socket = socket;}// 任務是為一個使用者提供服務@Overridepublic void run() {try {try {// 讀取用戶端傳過來資訊的DataInputStreamDataInputStream in = new DataInputStream(socket.getInputStream());// 向用戶端發送資訊的DataOutputStreamDataOutputStream out = new DataOutputStream(socket.getOutputStream());while (true) {// 讀取來自用戶端的資訊String accpet = in.readUTF();out.writeUTF("伺服器:" + accpet);}} finally {// 建立串連失敗的話不會執行socket.close();socket.close();}} catch (IOException e) {e.printStackTrace();}}}

用戶端代碼:

package demo.net;import java.io.DataInputStream;import java.io.DataOutputStream;import java.io.IOException;import java.net.Socket;import java.util.Scanner;/** * 注意用到的輸入輸出資料流DataInputStream和DataOutputStream,成對出現,最好用位元組流 */// 用戶端類public class ChatClients {private String host = "localhost";// 預設串連到本機private int port = 8189;// 預設串連到連接埠8189public ChatClients() {}// 串連到指定的主機和連接埠public ChatClients(String host, int port) {this.host = host;this.port = port;}public void chat() {try {// 串連到伺服器Socket socket = new Socket(host, port);try {// 讀取伺服器端傳過來資訊的DataInputStreamDataInputStream in = new DataInputStream(socket.getInputStream());// 向伺服器端發送資訊的DataOutputStreamDataOutputStream out = new DataOutputStream(socket.getOutputStream());// 裝飾標準輸入資料流,用於從控制台輸入Scanner scanner = new Scanner(System.in);while (true) {String send = scanner.nextLine();// 把從控制台得到的資訊傳送給伺服器out.writeUTF(send);// 讀取來自伺服器的資訊String accpet = in.readUTF();System.out.println(accpet);}} finally {socket.close();}} catch (IOException e) {e.printStackTrace();}}public static void main(String[] args) {new ChatClients().chat();}}


 

運行結果:

                                 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.