好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > UDP連接對象原理解析及使用實例

UDP連接對象原理解析及使用實例

熱門標簽:長沙回撥外呼系統 云南云電銷機器人招商 鸚鵡螺號航海地圖標注時間 信貸電銷機器人系統 比較穩定的外呼系統 江蘇自動外呼系統一般多少錢 ai電話機器人營銷 山東電信外呼系統靠譜嗎 400 電話 申請費用

之前寫了一個簡單的UDP服務端和客戶端示例,用于入門UDP,當我實際使用時發生了一點問題!

上次使用中我也把連接對象 DatagramSocket 寫成了靜態的,在類的初始化時使用,可是系統中有很多地方使用,難道我要不斷的創建這個類的對象嗎?

可以這么做,當時有后果,后果就是內存溢出。

UDP是沒有狀態的,DatagramSocket 創建一次即可,就是開始指向某個地址的端口,而不用每次創建。

由于UDP是無狀態的,在創建 DatagramSocket 對象時只是創建了一個指向網絡的對象,就像你架設一個大喇叭對著某個方向,可是你并不知道這個方向到底有沒有人在聽。

如果,即使你沒有開服務端,創建連接對象并向這個地址放松數據,都是沒有問題。你用喇叭向某個方向喊沒人聽這沒有什么!可是當你需要回應時如果一直沒有接到響應,超時之后就會報錯!

package udp; 
 
import java.net.*; 
 
/** 
 * @說明 UDP客戶端程序,用于對服務端發送數據,并接收服務端的回應信息 
 * @author cuisuqiang 
 * @version 1.0 
 * @since <a href="mailto:cuisuqiang@163.com" rel="external nofollow" >cuisuqiang@163.com</a> 
 */ 
public class UdpClientSocket { 
  /** 
   * 連接對象 
   */ 
  private static DatagramSocket ds = null; 
  /** 
   * 地址對象 
   */ 
  private static SocketAddress address = null; 
   
  /** 
   * 測試客戶端發包和接收回應信息的方法 
   */ 
  public static void main(String[] args) throws Exception { 
    init(); 
    while(true){ 
      UdpClientSocket.send(address,"你好,親愛的!".getBytes()); 
      UdpClientSocket.receive(); 
      try { 
        Thread.sleep(3 * 1000); 
      } catch (Exception e) { 
        e.printStackTrace(); 
      } 
    } 
  } 
   
  /** 
   * 對連接和地址初始化 
   */ 
  public static void init(){ 
    try { 
      ds = new DatagramSocket(8899); // 邦定本地端口作為客戶端 
      ds.setSoTimeout(2 * 1000); 
      address = new InetSocketAddress("127.0.0.1",3344); 
    } catch (Exception e) { 
      e.printStackTrace(); 
    } 
  } 
   
  /** 
   * 向指定的服務端發送數據信息 
   */ 
  public static void send(SocketAddress address,byte[] bytes){ 
    try { 
      DatagramPacket dp = new DatagramPacket(bytes, bytes.length, address); 
      ds.send(dp); 
    } catch (Exception e) { 
      e.printStackTrace(); 
    } 
  } 
 
  /** 
   * 接收從指定的服務端發回的數據 
   */ 
  public static void receive(){ 
    try { 
      byte[] buffer = new byte[1024]; 
      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());  
      System.out.println("服務端回應數據:" + new String(data)); 
    } catch (Exception e) { 
      e.printStackTrace(); 
    } 
  } 
} 

執行以代碼運行結果如下:

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 udp.UdpClientSocket.receive(UdpClientSocket.java:69)
at udp.UdpClientSocket.main(UdpClientSocket.java:28)

運行超時,但是報錯的地方不是創建對象和發送數據,而是接收數據時超時!

這個程序一直運行,我們來搞一個服務端:

package udp;

import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetSocketAddress;
import java.net.SocketAddress;

/**
 * @說明 UDP服務類
 * @author cuisuqiang
 * @version 1.0
 * @since cuisuqiang@163.com
 */
public class UdpServerSocket {
	
	private static DatagramSocket ds = null;
	private static SocketAddress address = null;
	
	/**
	 * 測試方法
	 */
	public static void main(String[] args) throws Exception {
		init();
		System.out.println("---->服務開始監聽!<----");
		while (true) {
			UdpServerSocket.receive();
			UdpServerSocket.response(address,"你好,吃了嗎!");
		}		
	}
	
	public static void init(){
		try {
			ds = new DatagramSocket(3344);
			ds.setSoTimeout(0);
			address = new InetSocketAddress("127.0.0.1",8899);
		} catch (Exception e) {
			e.printStackTrace();
		}
	}

	/**
	 * 接收數據包,該方法會造成線程阻塞
	 */
	public static void receive() {
		try {
			byte[] buffer = new byte[1024];
			DatagramPacket packet = new DatagramPacket(buffer, buffer.length);
			ds.receive(packet);
			String info = new String(packet.getData(), 0, packet.getLength());
			System.out.println("接收信息:" + info);
		} catch (Exception e) {
			e.printStackTrace();
		}
	}

	/**
	 * 將響應包發送給請求端
	 */
	public static void response(SocketAddress address,String info){
		try {
			DatagramPacket dp = new DatagramPacket(info.getBytes(), info.getBytes().length, address);
			dp.setData(info.getBytes());
			ds.send(dp);
		} catch (Exception e) {
			e.printStackTrace();
		}		
	}
}

運行后客戶端可以正常發送和接收數據!

如果在實際運用中,我是設置一個系統啟動項,來初始化 init 連接對象和地址,具體使用時進行異常捕獲就可以了!

如果你的連接對象每次創建,且使用頻繁,一般幾分鐘系統即可搞掛!

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

標簽:衡陽 澳門 亳州 烏海 運城 嘉興 齊齊哈爾 拉薩

巨人網絡通訊聲明:本文標題《UDP連接對象原理解析及使用實例》,本文關鍵詞  UDP,連接,對象,原理,解析,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《UDP連接對象原理解析及使用實例》相關的同類信息!
  • 本頁收集關于UDP連接對象原理解析及使用實例的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 疯皇子全文免费阅读| 丝瓜视频未满十八严禁下载| 白羊女会随便让人睡吗| 99久久婷婷国产一区二区三区| 国产亚洲精品久久久久久精品桃花岛| 国产精品久久久久久久久久| 亚洲秘?无码一区二区三区电影| ⅹxx日本护土| 久久网站视频| 玖玖热综合一区二区三区 | 小说主角夜麟| 激情四射影院| 美国一级黄色毛片| 亚洲另类激情专区小说婷婷久| 清冷受被做到崩溃np肉推荐| JIZZ学生18丝袜中国老师| 八戒,八戒影视大全2023年| 日本污视频| 成人亚洲网站| 被yin水喂养长大的小皇子| 日本videos有奶水的hd| 公交车猛烈进出婷婷| 欧美精品久久久久久日日迷棕林| yy6080久久国产伦理| 佐々木あき的无码96AV| 久草软件| 99RE久久精品国产| 被同桌用震蛋折磨很爽| juy869通野未帆在线观看| 国产AV无码亚洲AV无码成玥玥| 黑人极品巨大videoshd的设计| 婷婷成人亚洲综合国产| 深夜小黄站| 盖尔加朵裸乳无打码| 男人狂躁进女人下面视频网站| 69av片| 喜欢含着睡觉的高大体育生(h)| 国产女主播户外勾搭路人| 国产乱码精品AAAAAAAA| freeavhdvideo| 日本69×XX视频|