Java實(shí)現(xiàn)UDP多線程在線咨詢(xún)
本文實(shí)例為大家分享了Java實(shí)現(xiàn)UDP多線程在線咨詢(xún),供大家參考,具體內(nèi)容如下
1.發(fā)送的線程
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetSocketAddress;
import java.net.SocketException;
//發(fā)送線程
public class TalkSend implements Runnable {
DatagramSocket socket = null;
BufferedReader reader = null;
private int formPort; //自身端口
private String toIP; //發(fā)送到的IP
private int toPort; //發(fā)送到的端口
public TalkSend(int formPort, String toIP, int toPort) {
this.formPort = formPort;
this.toIP = toIP;
this.toPort = toPort;
try {
socket = new DatagramSocket(formPort);
reader = new BufferedReader(new InputStreamReader(System.in)); //獲取控制臺(tái)輸入
} catch (SocketException e) {
e.printStackTrace();
}
}
@Override
public void run() {
while(true) {
try {
String data = reader.readLine(); //獲取到的數(shù)據(jù)
byte[] datas = data.getBytes(); //轉(zhuǎn)換為需要的字節(jié)數(shù)組
//將數(shù)據(jù)打包成包
DatagramPacket packet = new DatagramPacket(datas,0, datas.length,new InetSocketAddress(this.toIP,this.toPort));
socket.send(packet); //發(fā)送包
//退出指令
if(packet.equals("bye")){
break;
}
} catch (IOException e) {
e.printStackTrace();
}
}
socket.close();
}
}
2.接收的線程
import java.io.IOException;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.SocketException;
//接收線程
public class TalkReceive implements Runnable {
DatagramSocket socket = null; //與發(fā)送端的socket為同一個(gè),實(shí)現(xiàn)通信
private int port;
private String msgFrom; //標(biāo)志信息來(lái)源
public TalkReceive(int port, String msgFrom) {
this.port = port;
this.msgFrom= msgFrom;
try {
socket = new DatagramSocket(port);
} catch (SocketException e) {
e.printStackTrace();
}
}
@Override
public void run() {
while (true){
try {
byte[] container = new byte[1024];
DatagramPacket packet = new DatagramPacket(container, 0, container.length);
socket.receive(packet);//接收數(shù)據(jù)
byte[] data = packet.getData();
String receiveData = new String(data, 0, data.length);
System.out.println(msgFrom+":"+receiveData);
if(receiveData.equals("bye")){
break;
}
} catch (IOException e) {
e.printStackTrace();
}
}
socket.close();
}
}
3.模擬學(xué)生端
//模擬學(xué)生
public class TalkStudent {
public static void main(String[] args) {
new Thread(new TalkSend(7777, "localhost", 9999)).start();
new Thread(new TalkReceive(8888, "老師")).start();
}
}
4.模擬老師端
//模擬老師
public class TalkTeacher {
public static void main(String[] args) {
new Thread(new TalkSend(5555, "localhost", 8888)).start();
new Thread(new TalkReceive(9999, "學(xué)生")).start();
}
}
5.截圖
學(xué)生端:

老師端:

6.總結(jié)
首先創(chuàng)建一個(gè)發(fā)送線程,里面定義要發(fā)送到的IP地址和端口,再創(chuàng)建一個(gè)DatagramSocket來(lái)進(jìn)行通信,創(chuàng)建一個(gè)BufferReader(new InputStreamReader(System.in))來(lái)獲取控制臺(tái)的輸入的數(shù)據(jù),將獲取到的數(shù)據(jù)打包進(jìn)行發(fā)送。之后創(chuàng)建一個(gè)接收線程,里面定義自身的端口即可,再創(chuàng)建一個(gè)和發(fā)送端一樣的DatagramSocket來(lái)進(jìn)行通信,接收數(shù)據(jù)進(jìn)行打印輸出即可。最后模擬學(xué)生端和老師端,創(chuàng)建這兩個(gè)線程來(lái)進(jìn)行通信。學(xué)生發(fā)送線程到的端口是老師的接收端口,老師發(fā)送的端口是學(xué)生的接收端口,這樣才能互相通信。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- java多線程創(chuàng)建及線程安全詳解
- Java多線程之線程同步
- Java多線程之ReentrantReadWriteLock源碼解析
- Java多線程之線程的創(chuàng)建
- Java多線程之synchronized關(guān)鍵字的使用
- Java多線程之Disruptor入門(mén)
- Java基礎(chǔ)之多線程的三種實(shí)現(xiàn)方式
- Java多線程之Park和Unpark原理
- Java多線程之哲學(xué)家就餐問(wèn)題詳解
- Java多線程之簡(jiǎn)單模擬售票功能
- 基于Java網(wǎng)絡(luò)編程和多線程的多對(duì)多聊天系統(tǒng)
- java的多線程高并發(fā)詳解
- 教你如何使用Java多線程編程LockSupport工具類(lèi)
- Java多線程之線程池七個(gè)參數(shù)詳解
- 總結(jié)java多線程之互斥與同步解決方案
相關(guān)文章
IDEA x64 exe文件打不開(kāi),bat能打開(kāi)問(wèn)題
這篇文章主要介紹了IDEA x64 exe文件打不開(kāi),bat能打開(kāi)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-11-11
uploadify上傳及后臺(tái)文件合法性驗(yàn)證的代碼解析
這篇文章主要介紹了uploadify上傳及后臺(tái)文件合法性驗(yàn)證的代碼解析,整段代碼分為后臺(tái)上傳方法,文件合法性驗(yàn)證類(lèi),前端上傳js,非常不錯(cuò)具有參考借鑒價(jià)值,需要的朋友可以參考下2016-11-11
MyBatis批量插入數(shù)據(jù)的三種方法實(shí)例
由于項(xiàng)目需要生成多條數(shù)據(jù),并保存到數(shù)據(jù)庫(kù)當(dāng)中,項(xiàng)目使用了Spring+MyBatis,所以打算使用MyBatis批量插入,應(yīng)該要比循環(huán)插入的效果更好,下面這篇文章主要給大家介紹了關(guān)于MyBatis批量插入數(shù)據(jù)的三種方法,需要的朋友可以參考下2021-10-10
Java訪問(wèn)Hadoop分布式文件系統(tǒng)HDFS的配置說(shuō)明
Hadoop的能提供高吞吐量的數(shù)據(jù)訪問(wèn),是集群式服務(wù)器的上的數(shù)據(jù)操作利器,這里就來(lái)為大家分享Java訪問(wèn)Hadoop分布式文件系統(tǒng)HDFS的配置說(shuō)明:2016-06-06
spring-boot中spring-boot-maven-plugin報(bào)紅錯(cuò)誤及解決
這篇文章主要介紹了spring-boot中spring-boot-maven-plugin報(bào)紅錯(cuò)誤及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03
k8s部署springboot實(shí)現(xiàn)前后端分離項(xiàng)目
本文主要介紹了k8s部署springboot實(shí)現(xiàn)前后端分離項(xiàng)目,主要包括配置文件、鏡像構(gòu)建和容器編排等方面,具有一定的參考價(jià)值,感興趣的可以了解一下2024-01-01
java如何給指定類(lèi)配置單獨(dú)的日志文件輸出
這篇文章主要介紹了java如何給指定類(lèi)配置單獨(dú)的日志文件輸出問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-04-04

