久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

Java使用MulticastSocket實(shí)現(xiàn)群聊應(yīng)用程序

這篇文章主要為大家詳細(xì)介紹了Java使用MulticastSocket實(shí)現(xiàn)群聊應(yīng)用程序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了Java使用MulticastSocket實(shí)現(xiàn)群聊應(yīng)用程序的具體代碼,供大家參考,具體內(nèi)容如下

在這篇文章中,討論了一個使用 MulticastSocket (Java Platform SE 7) 類的群聊應(yīng)用程序。MulticastSocket 是一個 (UDP) DatagramSocket,具有加入 Internet 上其他多播主機(jī)“組”的附加功能。

import java.net.*;
import java.io.*;
import java.util.*;
?
public class GroupChat {
?? ?private static final String TERMINATE = "Exit";
?? ?static String name;
?? ?static volatile boolean finished = false;
?
?? ?public static void main(String[] args) {
?? ??? ?if (args.length != 2)
?? ??? ??? ?System.out.println("Two arguments required: <multicast-host> <port-number>");
?? ??? ?else {
?? ??? ??? ?try {
?? ??? ??? ??? ?InetAddress group = InetAddress.getByName(args[0]);
?? ??? ??? ??? ?int port = Integer.parseInt(args[1]);
?? ??? ??? ??? ?Scanner sc = new Scanner(System.in);
?? ??? ??? ??? ?System.out.print("Enter your name: ");
?? ??? ??? ??? ?name = sc.nextLine();
?? ??? ??? ??? ?MulticastSocket socket = new MulticastSocket(port);
?
?? ??? ??? ??? ?// Since we are deploying
?? ??? ??? ??? ?socket.setTimeToLive(0);
?? ??? ??? ??? ?// this on localhost only (For a subnet set it as 1)
?
?? ??? ??? ??? ?socket.joinGroup(group);
?? ??? ??? ??? ?Thread t = new Thread(new ReadThread(socket, group, port));
?
?? ??? ??? ??? ?// Spawn a thread for reading messages
?? ??? ??? ??? ?t.start();
?
?? ??? ??? ??? ?// sent to the current group
?? ??? ??? ??? ?System.out.println("Start typing messages...\n");
?? ??? ??? ??? ?while (true) {
?? ??? ??? ??? ??? ?String message;
?? ??? ??? ??? ??? ?message = sc.nextLine();
?? ??? ??? ??? ??? ?if (message.equalsIgnoreCase(GroupChat.TERMINATE)) {
?? ??? ??? ??? ??? ??? ?finished = true;
?? ??? ??? ??? ??? ??? ?socket.leaveGroup(group);
?? ??? ??? ??? ??? ??? ?socket.close();
?? ??? ??? ??? ??? ??? ?break;
?? ??? ??? ??? ??? ?}
?? ??? ??? ??? ??? ?message = name + ": " + message;
?? ??? ??? ??? ??? ?byte[] buffer = message.getBytes();
?? ??? ??? ??? ??? ?DatagramPacket datagram = new DatagramPacket(buffer, buffer.length, group, port);
?? ??? ??? ??? ??? ?socket.send(datagram);
?? ??? ??? ??? ?}
?? ??? ??? ?} catch (SocketException se) {
?? ??? ??? ??? ?System.out.println("Error creating socket");
?? ??? ??? ??? ?se.printStackTrace();
?? ??? ??? ?} catch (IOException ie) {
?? ??? ??? ??? ?System.out.println("Error reading/writing from/to socket");
?? ??? ??? ??? ?ie.printStackTrace();
?? ??? ??? ?}
?? ??? ?}
?? ?}
}
?
class ReadThread implements Runnable {
?? ?private MulticastSocket socket;
?? ?private InetAddress group;
?? ?private int port;
?? ?private static final int MAX_LEN = 1000;
?
?? ?ReadThread(MulticastSocket socket, InetAddress group, int port) {
?? ??? ?this.socket = socket;
?? ??? ?this.group = group;
?? ??? ?this.port = port;
?? ?}
?
?? ?@Override
?? ?public void run() {
?? ??? ?while (!GroupChat.finished) {
?? ??? ??? ?byte[] buffer = new byte[ReadThread.MAX_LEN];
?? ??? ??? ?DatagramPacket datagram = new DatagramPacket(buffer, buffer.length, group, port);
?? ??? ??? ?String message;
?? ??? ??? ?try {
?? ??? ??? ??? ?socket.receive(datagram);
?? ??? ??? ??? ?message = new String(buffer, 0, datagram.getLength(), "UTF-8");
?? ??? ??? ??? ?if (!message.startsWith(GroupChat.name))
?? ??? ??? ??? ??? ?System.out.println(message);
?? ??? ??? ?} catch (IOException e) {
?? ??? ??? ??? ?System.out.println("Socket closed!");
?? ??? ??? ?}
?? ??? ?}
?? ?}
}

將文件另存為 GroupChat.java 并使用 javac 編譯它,然后使用指定的兩個命令行參數(shù)運(yùn)行程序。多播主機(jī)由 D 類 IP 地址和標(biāo)準(zhǔn) UDP 端口號指定。D 類 IP 地址的范圍為 224.0.0.0 到 239.255.255.255(含)。地址 224.0.0.0 是保留地址,不應(yīng)使用。
以下是上述程序的示例輸出:

我們使用多播主機(jī) IP 地址為 239.0.0.0,端口號為 1234(因?yàn)槎丝谔?0 到 1023 被保留)。該組有 3 名成員:Ironman、CaptainAmerica 和 Groot。在發(fā)送消息之前首先啟動所有三個終端,否則在啟動終端之前發(fā)送的消息將丟失(因?yàn)闆]有合并緩沖區(qū)來存儲消息。)我們在這個應(yīng)用程序中需要兩個線程。一個用于接受用戶輸入(使用 java.util.Scanner 類),另一個用于讀取從其他客戶端發(fā)送的消息。因此,我將執(zhí)行讀取工作的線程分離到 ReadThreadclass 中。要離開組,任何用戶都可以鍵入退出以終止會話。

上述程序在單機(jī)上執(zhí)行。套接字編程適用于分布式編程。相同的代碼片段出現(xiàn)在安裝了 Java 的不同機(jī)器上時可以滿足該要求。這只是最基本的服務(wù)邏輯。如果前端開發(fā)出來,這個項(xiàng)目會更加吸引人。您可以使用 Java 的 AWT(抽象窗口工具包)或其高級對應(yīng)物 Java Swing 來開發(fā)前端。由于這不是 Socket 編程的一部分,因此我將在不深入了解細(xì)節(jié)的情況下保持不變。
附加點(diǎn):

您可以通過在通過網(wǎng)絡(luò)發(fā)送消息之前執(zhí)行加密來合并網(wǎng)絡(luò)安全功能。
凱撒密碼等原始技術(shù)或 RSA 等高級方法可用于執(zhí)行加解密。您可以嘗試使用 Java 的 RMI(遠(yuǎn)程方法調(diào)用)來執(zhí)行相同的任務(wù)。
在這里,您可以最大限度地利用 Java 提供的抽象。但是,如果您的主要目標(biāo)是效率,那么 Socket 編程是最佳選擇。由于它不需要任何運(yùn)行時支持,因此與 RMI 相比要快一些。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持html5模板網(wǎng)。

【網(wǎng)站聲明】本站部分內(nèi)容來源于互聯(lián)網(wǎng),旨在幫助大家更快的解決問題,如果有圖片或者內(nèi)容侵犯了您的權(quán)益,請聯(lián)系我們刪除處理,感謝您的支持!

相關(guān)文檔推薦

用戶上傳大文件,網(wǎng)絡(luò)差點(diǎn)的需要?dú)v時數(shù)小時,萬一線路中斷,不具備斷點(diǎn)續(xù)傳的服務(wù)器就只能從頭重傳,而斷點(diǎn)續(xù)傳就是,允許用戶從上傳斷線的地方繼續(xù)傳送,這樣大大減少了用戶的
有的時候我們需要鼠標(biāo)一直滑動的情況,為了節(jié)省時間,本文用Java語言寫了一個腳本,可以實(shí)現(xiàn)鼠標(biāo)隨機(jī)移動,感興趣的小伙伴可以了解一下
這篇文章主要為大家詳細(xì)介紹了java網(wǎng)絡(luò)編程之群聊功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
這篇文章主要為大家介紹了JavaString中intern方法的原理以及使用。文中通過圖片和示例代碼進(jìn)行了詳細(xì)展示,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
這篇文章主要介紹了Java中用戶線程與守護(hù)線程的使用區(qū)別,Java語言中無論是線程還是線程池,默認(rèn)都是用戶線程,因此用戶線程也被成為普通線程,下文關(guān)于其與守護(hù)線程的區(qū)別詳情,
本文主要介紹了Java中ReentrantLock?4種常見的坑,ReentrantLock默認(rèn)情況下為非公平鎖,下文關(guān)于其更多詳情需要的小伙伴可以參考一下
主站蜘蛛池模板: 精品国产欧美一区二区三区成人 | 欧美精品三区 | 久久久精品天堂 | 91免费看片 | 欧美激情国产日韩精品一区18 | 二区高清| 夜夜骑天天干 | 99国产视频 | 色综合久久88色综合天天 | 午夜免费精品视频 | 色播久久久| 日韩一区二区三区在线观看 | 免费在线一区二区三区 | 午夜精品久久久 | 免费成人国产 | 日本高清视频在线播放 | 精品一区二区三区四区外站 | 中文字幕一区二区三 | 在线免费观看a级片 | 伊人精品国产 | 不卡av在线 | 日韩成人 | 成人精品久久久 | 蜜月aⅴ国产精品 | 成人久久网| 免费视频成人国产精品网站 | 午夜噜噜噜 | 97色在线视频 | 亚洲欧美日韩精品久久亚洲区 | 国产中文视频 | 91网站在线看| 黄色片网站在线观看 | 国产精品视频一区二区三区不卡 | 偷拍自拍网站 | 久久国产精品一区二区三区 | 亚洲精品视频一区 | 九九福利 | 国产精品亚洲精品久久 | 欧美中文视频 | 精品国产乱码久久久久久图片 | 一区二区三区不卡视频 |