Java實現(xiàn)UDP多線程在線咨詢
本文實例為大家分享了Java實現(xiàn)UDP多線程在線咨詢,供大家參考,具體內(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)); //獲取控制臺輸入 } 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為同一個,實現(xiàn)通信 private int port; private String msgFrom; //標(biāo)志信息來源 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)建一個發(fā)送線程,里面定義要發(fā)送到的IP地址和端口,再創(chuàng)建一個DatagramSocket來進(jìn)行通信,創(chuàng)建一個BufferReader(new InputStreamReader(System.in))來獲取控制臺的輸入的數(shù)據(jù),將獲取到的數(shù)據(jù)打包進(jìn)行發(fā)送。之后創(chuàng)建一個接收線程,里面定義自身的端口即可,再創(chuàng)建一個和發(fā)送端一樣的DatagramSocket來進(jìn)行通信,接收數(shù)據(jù)進(jìn)行打印輸出即可。最后模擬學(xué)生端和老師端,創(chuàng)建這兩個線程來進(jìn)行通信。學(xué)生發(fā)送線程到的端口是老師的接收端口,老師發(fā)送的端口是學(xué)生的接收端口,這樣才能互相通信。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- java多線程創(chuàng)建及線程安全詳解
- Java多線程之線程同步
- Java多線程之ReentrantReadWriteLock源碼解析
- Java多線程之線程的創(chuàng)建
- Java多線程之synchronized關(guān)鍵字的使用
- Java多線程之Disruptor入門
- Java基礎(chǔ)之多線程的三種實現(xiàn)方式
- Java多線程之Park和Unpark原理
- Java多線程之哲學(xué)家就餐問題詳解
- Java多線程之簡單模擬售票功能
- 基于Java網(wǎng)絡(luò)編程和多線程的多對多聊天系統(tǒng)
- java的多線程高并發(fā)詳解
- 教你如何使用Java多線程編程LockSupport工具類
- Java多線程之線程池七個參數(shù)詳解
- 總結(jié)java多線程之互斥與同步解決方案
相關(guān)文章
Java訪問Hadoop分布式文件系統(tǒng)HDFS的配置說明
Hadoop的能提供高吞吐量的數(shù)據(jù)訪問,是集群式服務(wù)器的上的數(shù)據(jù)操作利器,這里就來為大家分享Java訪問Hadoop分布式文件系統(tǒng)HDFS的配置說明:2016-06-06spring-boot中spring-boot-maven-plugin報紅錯誤及解決
這篇文章主要介紹了spring-boot中spring-boot-maven-plugin報紅錯誤及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03k8s部署springboot實現(xiàn)前后端分離項目
本文主要介紹了k8s部署springboot實現(xiàn)前后端分離項目,主要包括配置文件、鏡像構(gòu)建和容器編排等方面,具有一定的參考價值,感興趣的可以了解一下2024-01-01