您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關UDP DUP超時如何使用UPD端口狀態檢測,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。
ds.setSoTimeout(5000);即為收數超時時間,如果不設置,那就是等待,比電視劇里面愛情片都漫長的等待,而且結果是一樣的,都是把自己等死了就不再等了。但是這個超時時間不能當作是你這個請求的超時時間,請注意這個概念,因為這個超時只是用于標記這段時間沒有從網絡中獲取數據,但是即使獲取數據了,那也不一定是你的,這個下面看示例就會明白。
然后就是端口問題,上面也說了你可以自己指定端口,也可以是把自己當作客戶端,需要發送數據時就創建一個連接對象然后發送數據,這樣端口就是動態的。意思就是說,只要DatagramSocket對象沒有被重新初始化或消失,那么本地打開的這個UDP端口就不會關閉。
然后就是UDP狀態的問題,其實早先就也有一篇文章了, UDP連接對象的理解和使用。無狀態是說這個連接沒有狀態,鬼知道他到底有沒有服務端,鬼也不知道就算那個服務端在他到底死了沒有。但是對于本地來說,如果你的DatagramSocket對象一直存在,那么你的本地端口就是有狀態的,他是活的。
然后做一個示例:
package test; import java.io.*; import java.net.*; import java.util.Arrays; /** * UDP客戶端程序,用于對服務端發送數據,并接收服務端的回應信息 */ public class UdpClientSocket { private byte[] buffer = new byte[1024]; private static DatagramSocket ds = null; /** * 測試客戶端發包和接收回應信息的方法 */ public static void main(String[] args) throws Exception { UdpClientSocket client = new UdpClientSocket(); String serverHost = "127.0.0.1"; int serverPort = 10002; client.send(serverHost, serverPort, new byte[]{1,2,3,4,5}); while(true){ byte[] bt = client.receive(); if(null != bt && bt.length > 0) System.out.println("收到數據:" + Arrays.toString(bt)); Thread.sleep(1000); } } /** * 構造函數,創建UDP客戶端 */ public UdpClientSocket() throws Exception { ds = new DatagramSocket(8899); // 邦定本地端口作為客戶端 ds.setSoTimeout(5000); } /** * 向指定的服務端發送數據信息 */ public final void send(final String host, final int port,final byte[] bytes) throws IOException { DatagramPacket dp = new DatagramPacket(bytes, bytes.length, InetAddress.getByName(host), port); ds.send(dp); } /** * 接收從指定的服務端發回的數據 */ public final byte[] receive() throws Exception { try { DatagramPacket dp = new DatagramPacket(buffer, buffer.length); ds.receive(dp); byte[] data = new byte[dp.getLength()]; System.arraycopy(dp.getData(), 0, data, 0, dp.getLength()); return data; } catch (Exception e) { e.printStackTrace(); return null; } } }
運行一直報錯:
java.net.SocketTimeoutException: Receive timed out
at java.net.PlainDatagramSocketImpl.receive0(Native Method)
at java.net.PlainDatagramSocketImpl.receive(PlainDatagramSocketImpl.java:136)
at java.net.DatagramSocket.receive(DatagramSocket.java:712)
at test.UdpClientSocket.receive(UdpClientSocket.java:46)
at test.UdpClientSocket.main(UdpClientSocket.java:20)
java.net.SocketTimeoutException: Receive timed out
at java.net.PlainDatagramSocketImpl.receive0(Native Method)
at java.net.PlainDatagramSocketImpl.receive(PlainDatagramSocketImpl.java:136)
at java.net.DatagramSocket.receive(DatagramSocket.java:712)
at test.UdpClientSocket.receive(UdpClientSocket.java:46)
at test.UdpClientSocket.main(UdpClientSocket.java:20)
使用TCPUDPDbg向8899發送數據,可以收到:
收到數據:[16, 17, 18, 19, 20]
這里示例中已經寫明
1.本地端口是8899
2.收數超時時間是5秒
3.向本地10002端口發送了一組數據,鬼知道有沒有收到
4.不斷獲取本地端口8899收到的UDP數據
然后發現
1.發送數據沒有報錯
2.一直報錯收數超時
3.使用TCPUDPDbg向8899發送數據能夠收到
總結:
1.UDP能指定收數超時,但是每個請求的超時需要自己控制
2.UDP可以邦定本地端口發數,而且這個端口可以有狀態存活
3.UDP沒有狀態,但是本地可以有
看完上述內容,你們對UDP DUP超時如何使用UPD端口狀態檢測有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。