java編程實現(xiàn)基于UDP協(xié)議傳輸數(shù)據(jù)的方法
本文實例講述了java編程實現(xiàn)基于UDP協(xié)議傳輸數(shù)據(jù)的方法。分享給大家供大家參考,具體如下:
UDP協(xié)議(User Datagram Protocol,用戶數(shù)據(jù)報協(xié)議)不同于TCP協(xié)議,它是不可能靠的,但是它比TCP協(xié)議具有更快的傳輸速度,UDP發(fā)送的數(shù)據(jù)單元稱為數(shù)據(jù)報,當(dāng)網(wǎng)絡(luò)傳輸U(kuò)DP傳輸U(kuò)DP數(shù)據(jù)報是無法保證數(shù)據(jù)能夠到達(dá)目的地,也無法保證按發(fā)送的順序到達(dá)目的地,也就是說先發(fā)送了“hello”,再發(fā)送了“world”,但接收方可能會先收到“world”,再收到“hello”,也有可能收不到數(shù)據(jù),為什么呢?因為它是不可能靠的,在傳輸途中可能丟失了。但UDP比TCP跟適合與傳輸實時音頻。下面是一個簡單的UPD傳輸數(shù)據(jù)報的例子
服務(wù)器端:
import java.io.IOException;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.SocketException;
public class EchoServer {
private DatagramSocket datagramSocket;
private final int port = 8088;
public static void main(String[] args) throws SocketException {
new EchoServer().service();
}
public EchoServer() throws SocketException{
datagramSocket = new DatagramSocket(port);
System.out.println("服務(wù)器啟動");
}
public String echo(String msg){
return "echo:"+msg;
}
public void service(){
while (true) {
try {
DatagramPacket packet = new DatagramPacket(new byte[512], 512);
datagramSocket.receive(packet);
String msg = new String(packet.getData(), 0, packet.getLength());
System.out.println(packet.getAddress()+"/"+packet.getPort()+" msg:"+msg);
packet.setData(echo(msg).getBytes());
datagramSocket.send(packet);
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
客戶端:
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress;
import java.net.SocketException;
public class EchoClient {
private String remoteHost="localhost";
private int remotePort=8088;
private DatagramSocket datagramSocket;
public EchoClient() throws SocketException{
datagramSocket = new DatagramSocket();
}
public static void main(String[] args) throws SocketException {
new EchoClient().talk();
}
public void talk(){
try {
BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
String msg = null;
InetAddress address = InetAddress.getByName(remoteHost);
while ((msg=reader.readLine())!=null) {
//發(fā)送數(shù)據(jù)報
byte [] buffer = msg.getBytes();
DatagramPacket packet = new DatagramPacket(buffer,buffer.length, address, remotePort);
datagramSocket.send(packet);
//接收數(shù)據(jù)報
DatagramPacket inputPacket = new DatagramPacket(new byte[512], 512);
datagramSocket.receive(inputPacket);
System.out.println(new String(inputPacket.getData(), 0 , inputPacket.getLength()));
if("bye".equals(msg)){
break;
}
}
} catch (IOException e) {
e.printStackTrace();
}finally{
datagramSocket.close();
}
}
希望本文所述對大家Java程序設(shè)計有所幫助。
相關(guān)文章
Java HashSet集合存儲遍歷學(xué)生對象代碼實例
這篇文章主要介紹了Java HashSet集合存儲遍歷學(xué)生對象代碼實例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-04-04
解析SpringBoot整合SpringDataRedis的過程
這篇文章主要介紹了SpringBoot整合SpringDataRedis的過程,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-06-06
VSCode?配置?Spring?Boot?項目開發(fā)環(huán)境的全過程
兩三年前曾經(jīng)試過配置Java環(huán)境, 存在不少問題作罷. 最近搜了下相關(guān)的文章, 感覺VSCode對Java項目的支持比三年前完善了不少. 今天實際配置了一下環(huán)境, 把自己常用的功能過了一遍, 基本能跑通開發(fā)流程, 做個筆記,需要的朋友可以參考下2024-03-03
java并發(fā)編程專題(一)----線程基礎(chǔ)知識
這篇文章主要介紹了java并發(fā)編程線程的基礎(chǔ)知識,文中講解非常詳細(xì),幫助大家更好的學(xué)習(xí)JAVA并發(fā)編程,感興趣想學(xué)習(xí)JAVA的可以了解下2020-06-06
Mybatis讀取和存儲json類型數(shù)據(jù)的實現(xiàn)
本文主要介紹了Mybatis讀取和存儲json類型數(shù)據(jù)的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06
Java連接并操作Sedna XML數(shù)據(jù)庫的方法
這篇文章主要介紹了Java連接并操作Sedna XML數(shù)據(jù)庫的方法,較為詳細(xì)的說明了Sedna XML數(shù)據(jù)庫的原理與功能,并給出了基于java操作Sedna XML數(shù)據(jù)庫的方法,需要的朋友可以參考下2015-06-06

