欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java實現(xiàn)多客戶聊天功能

 更新時間:2021年08月27日 12:24:51   作者:最好的碩碩  
這篇文章主要為大家詳細介紹了java實現(xiàn)多客戶聊天功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

java 實現(xiàn)多客戶端聊天(TCP),供大家參考,具體內(nèi)容如下

1. 編程思想:

1)、要想實現(xiàn)多客戶端聊天,首先需要有多個客戶端,而這些客戶端需要隨時發(fā)送消息和接受消息,所以收發(fā)消息需要放入不同的線程中。

2)、多客戶聊天并不是多個客戶之間進行兩兩通信,而是需要所有客戶端與服務端進行交互,再由服務端統(tǒng)一下發(fā)信息到其他參與聊天的客戶端。

2. 代碼實現(xiàn):

2.1 實現(xiàn)專用于接收消息的子線程ReceiveThread

將接收消息和發(fā)送消息分為兩個線程,其中將發(fā)送消息寫入主線程中,開啟新的線程用于接收消息。

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.Socket;

public class ReceiveThread extends Thread{

 private Socket socket; //私有的成員變量,套接字
 
 public ReceiveThread(Socket socket) {
  this.socket = socket;
 }

 @Override
 public void run() {
  BufferedReader br = null;//使用帶緩沖區(qū)的字符輸入流接收信息
  try {
   br = new BufferedReader(new InputStreamReader(socket.getInputStream()));
  } catch (IOException e) {
   e.printStackTrace();
  }
  while(true){
   try {
    System.out.println(br.readLine());
   } catch (IOException e) {
    e.printStackTrace();
   }
  }
 }
}

2.2 客戶端代碼

import java.io.IOException;
import java.io.PrintStream;
import java.net.Socket;
import java.net.UnknownHostException;
import java.util.Scanner;

public class Client {
 @SuppressWarnings("all")
 public static void main(String[] args) throws UnknownHostException, IOException {  
        //ip:需要連接的服務端所在的ip
        //端口:客戶端連接的端口必須和服務端端口一致
  Socket socket = new Socket("192.168.*.*",8080);
  Scanner scan = new Scanner(System.in);
  new ReceiveThread(socket).start();
  //發(fā)送給服務端信息
  while(true ){
   PrintStream ps = new PrintStream(socket.getOutputStream());
   ps.println("一號:"+scan.next());  
  }
 }
}

注:

1)、客戶端代碼可以在局域網(wǎng)下的多臺電腦上運行,只需要將ip地址改為服務端的ip,就能夠連接。

2)、如果想要使用同臺電腦完成一個服務端和兩個客戶端運行,進行測試多人聊天,可創(chuàng)建客戶端2,使用本機ip

Socket socket = new Socket("127.0.0.1",8080);
Scanner scan = new Scanner(System.in);
new ReceiveThread(socket).start();
//發(fā)送給服務端信息
while(true ){
    PrintStream ps = new PrintStream(socket.getOutputStream());
    ps.println("二號:"+scan.next());  
}

2.3 服務端接收和轉發(fā)信息的線程ServerThread

服務端在每一個客戶端進行連接時,都會產(chǎn)生一個線程,用于服務這個客戶,負責接收該客戶發(fā)送的信息,并轉發(fā)到參與多人聊天的其他客戶。

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.PrintStream;
import java.net.InetAddress;
import java.net.Socket;
import java.util.Map.Entry;
import java.util.Set;

public class ServerThread  extends Thread{

 private Socket socket;
 
 public ServerThread(Socket socket) {
  this.socket = socket;
 }
 @Override
 public void run() {
  BufferedReader br = null;
  String str=null;
  try {
   br = new BufferedReader(new InputStreamReader(socket.getInputStream()));
  } catch (IOException e) {
   e.printStackTrace();
  }
  while(true){
   try {
    str=br.readLine();
                //在服務端輸出,可以監(jiān)測到所有人的聊天信息。
    System.out.println(str);
    
    //發(fā)送到其他客戶端
    Set<Entry<InetAddress, Socket>> entrySet = Server.map.entrySet();
    for (Entry<InetAddress, Socket> entry : entrySet) {
     InetAddress key = entry.getKey();
     Socket value = entry.getValue();
     if(socket.getInetAddress()!=key){
      PrintStream printStream = new PrintStream(value.getOutputStream());
      printStream.println(str);
     }
    }
    
   } catch (IOException e) {
    e.printStackTrace();
   }
  }
 }
}

2.4 服務端代碼

import java.io.IOException;
import java.net.InetAddress;
import java.net.ServerSocket;
import java.net.Socket;
import java.util.concurrent.ConcurrentHashMap;

public class Server {
 @SuppressWarnings("all")
    
 public static ConcurrentHashMap<InetAddress, Socket> map =new ConcurrentHashMap<>();
 public static void main(String[] args) throws IOException, InterruptedException {

  //創(chuàng)建服務端的ServerSocket
  ServerSocket server = new ServerSocket(8080);
  while(true){
            //接收到客戶連接就創(chuàng)建一個對應的套接字
   Socket socket = server.accept();
            //獲取該客戶的ip
   InetAddress inetAddress = socket.getInetAddress();
   //將該客戶的ip和套接字裝入map集合
   map.put(inetAddress, socket);
            //創(chuàng)建新的線程服務該客戶
   new ServerThread(socket).start();
  }  
 }
}

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • Java?MyBatis本地緩存原理詳解

    Java?MyBatis本地緩存原理詳解

    這篇文章主要介紹了Java?MyBatis本地緩存原理詳解,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-07-07
  • 簡單講解Java設計模式編程中的單一職責原則

    簡單講解Java設計模式編程中的單一職責原則

    這篇文章主要介紹了Java設計模式編程中的單一職責原則,這在團隊開發(fā)編寫接口時經(jīng)常使用這樣的約定,需要的朋友可以參考下
    2016-02-02
  • 淺談java 面對對象(抽象 繼承 接口 多態(tài))

    淺談java 面對對象(抽象 繼承 接口 多態(tài))

    下面小編就為大家?guī)硪黄獪\談java 面對對象(抽象 繼承 接口 多態(tài))。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-02-02
  • SpringCloud如何使用Eureka實現(xiàn)服務之間的傳遞數(shù)據(jù)

    SpringCloud如何使用Eureka實現(xiàn)服務之間的傳遞數(shù)據(jù)

    這篇文章主要介紹了SpringCloud使用Eureka實現(xiàn)服務之間的傳遞數(shù)據(jù)操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • Java中synchronized實現(xiàn)原理詳解

    Java中synchronized實現(xiàn)原理詳解

    這篇文章主要介紹了Java中synchronized實現(xiàn)原理詳解,涉及synchronized實現(xiàn)同步的基礎,Java對象頭,Monitor,Mark Word,鎖優(yōu)化,自旋鎖等相關內(nèi)容,具有一定借鑒價值,需要的朋友可以參考下。
    2017-11-11
  • Java中的static關鍵字深入理解

    Java中的static關鍵字深入理解

    這篇文章主要介紹了Java中的static關鍵字深入理解,文字和代碼列舉了實際例子,有感興趣的同學可以研究下
    2021-03-03
  • Java中==與equals的區(qū)別小結

    Java中==與equals的區(qū)別小結

    這篇文章主要介紹了Java中==與equals的區(qū)別小結,本文總結結論:== 與 equals()比較的內(nèi)容是不同的,equals()方式是String類中的方法,它用于比較兩個對象引用所指的內(nèi)容是否相等,而 == 比較的是兩個對象引用的地址是否相等,需要的朋友可以參考下
    2015-06-06
  • 淺談Java高并發(fā)解決方案以及高負載優(yōu)化方法

    淺談Java高并發(fā)解決方案以及高負載優(yōu)化方法

    這篇文章主要介紹了淺談Java高并發(fā)解決方案以及高負載優(yōu)化方法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • maven如何使用slf4j輸出日志到文件

    maven如何使用slf4j輸出日志到文件

    這篇文章主要介紹了maven如何使用slf4j輸出日志到文件,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • JAVA項目字典與緩存搭配使用方法解析

    JAVA項目字典與緩存搭配使用方法解析

    這篇文章主要介紹了JAVA項目字典與緩存搭配使用方法解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-09-09

最新評論