當前位置:首頁 > 物聯(lián)網(wǎng) > 網(wǎng)絡(luò)協(xié)議
[導讀]   在進行UDP協(xié)議的使用中,我們通常會借助其他語言工具來完成工作。那么今天我們主要介紹一下Java下的UDP協(xié)議的使用。首先我們來了解一下UDP協(xié)議的基本概念。UDP協(xié)議的全稱是用戶數(shù)據(jù)報,在

  在進行UDP協(xié)議的使用中,我們通常會借助其他語言工具來完成工作。那么今天我們主要介紹一下Java下的UDP協(xié)議的使用。首先我們來了解一下UDP協(xié)議的基本概念。UDP協(xié)議的全稱是用戶數(shù)據(jù)報,在網(wǎng)絡(luò)中它與TCP協(xié)議一樣用于處理數(shù)據(jù)包?在OSI模型中,在第四層??傳輸層,處于IP協(xié)議的上一層?UDP有不提供數(shù)據(jù)報分組?組裝和不能對數(shù)據(jù)包的排序的缺點,也就是說,當報文發(fā)送之后,是無法得知其是否安全完整到達的?

  為什么要使用UDP

  在選擇使用協(xié)議的時候,選擇UDP必須要謹慎?在網(wǎng)絡(luò)質(zhì)量令人不十分滿意的環(huán)境下,UDP協(xié)議數(shù)據(jù)包丟失會比較嚴重?但是由于UDP的特性:它不屬于連接型協(xié)議,因而具有資源消耗小,處理速度快的優(yōu)點,所以通常音頻?視頻和普通數(shù)據(jù)在傳送時使用UDP較多,因為它們即使偶爾丟失一兩個數(shù)據(jù)包,也不會對接收結(jié)果產(chǎn)生太大影響?比如我們聊天用的ICQ和OICQ就是使用的UDP協(xié)議?

  一、使用DatagramSocket發(fā)送、接收數(shù)據(jù)原理

  Java使用DatagramSocket代表UDP協(xié)議的Socket,DatagramSocket本身只是碼頭,不維護狀態(tài),不能產(chǎn)生IO流,它的唯一作用就是接收和發(fā)送數(shù)據(jù)報,Java使用DatagramPacket來代表數(shù)據(jù)報,DatagramSocket接收和發(fā)送的數(shù)據(jù)都是通過DatagramPacket對象完成的。

  1. DatagramSocket的構(gòu)造器

  DatagramSocket():創(chuàng)建一個DatagramSocket實例,并將該對象綁定到本機默認IP地址、本機所有可用端口中隨機選擇的某個端口。

  DatagramSocket(int prot):創(chuàng)建一個DatagramSocket實例,并將該對象綁定到本機默認IP地址、指定端口。

  DatagramSocket(int port, InetAddress laddr):創(chuàng)建一個DatagramSocket實例,并將該對象綁定到指定IP地址、指定端口。

  通過上面三個構(gòu)造器中的任意一個構(gòu)造器即可創(chuàng)建一個DatagramSocket實例,通常在創(chuàng)建服務器時,創(chuàng)建指定端口的DatagramSocket實例--這樣保證其他客戶端可以將數(shù)據(jù)發(fā)送到該服務器。一旦得到了DatagramSocket實例之后,就可以通過如下兩個方法來接收和發(fā)送數(shù)據(jù)。

  receive(DatagramPacket p):從該DatagramSocket中接收數(shù)據(jù)報。

  send(DatagramPacket p):以該DatagramSocket對象向外發(fā)送數(shù)據(jù)報。

  從上面兩個方法可以看出,使用DatagramSocket發(fā)送數(shù)據(jù)報時,DatagramSocket并不知道將該數(shù)據(jù)報發(fā)送到哪里,而是由DatagramPacket自身決定數(shù)據(jù)報的目的地。就像碼頭并不知道每個集裝箱的目的地,碼頭只是將這些集裝箱發(fā)送出去,而集裝箱本身包含了該集裝箱的目的地。

  2. DatagramPacket的構(gòu)造器

  DatagramPacket(byte[] buf,int length):以一個空數(shù)組來創(chuàng)建DatagramPacket對象,該對象的作用是接收DatagramSocket中的數(shù)據(jù)。

  DatagramPacket(byte[] buf, int length, InetAddress addr, int port):以一個包含數(shù)據(jù)的數(shù)組來創(chuàng)建DatagramPacket對象,創(chuàng)建該DatagramPacket對象時還指定了IP地址和端口--這就決定了該數(shù)據(jù)報的目的地。

  DatagramPacket(byte[] buf, int offset, int length):以一個空數(shù)組來創(chuàng)建DatagramPacket對象,并指定接收到的數(shù)據(jù)放入buf數(shù)組中時從offset開始,最多放length個字節(jié)。

  DatagramPacket(byte[] buf, int offset, int length, InetAddress address, int port):創(chuàng)建一個用于發(fā)送的DatagramPacket對象,指定發(fā)送buf數(shù)組中從offset開始,總共length個字節(jié)。

  當Client/Server程序使用UDP協(xié)議時,實際上并沒有明顯的服務器端和客戶端,因為兩方都需要先建立一個DatagramSocket對象,用來接收或發(fā)送數(shù)據(jù)報,然后使用DatagramPacket對象作為傳輸數(shù)據(jù)的載體。通常固定IP地址、固定端口的DatagramSocket對象所在的程序被稱為服務器,因為該DatagramSocket可以主動接收客戶端數(shù)據(jù)。

  在接收數(shù)據(jù)之前,應該采用上面的第一個或第三個構(gòu)造器生成一個DatagramPacket對象,給出接收數(shù)據(jù)的字節(jié)數(shù)組及其長度。然后調(diào)用DatagramSocket 的receive()方法等待數(shù)據(jù)報的到來,receive()將一直等待(該方法會阻塞調(diào)用該方法的線程),直到收到一個數(shù)據(jù)報為止。
 

        如下代碼所示:

  // 創(chuàng)建一個接收數(shù)據(jù)的DatagramPacket對象

  DatagramPacket packet=new DatagramPacket(buf, 256);

  // 接收數(shù)據(jù)報

  socket.receive(packet);

  在發(fā)送數(shù)據(jù)之前,調(diào)用第二個或第四個構(gòu)造器創(chuàng)建DatagramPacket對象,此時的字節(jié)數(shù)組里存放了想發(fā)送的數(shù)據(jù)。除此之外,還要給出完整的目的地址,包括IP地址和端口號。發(fā)送數(shù)據(jù)是通過DatagramSocket的send()方法實現(xiàn)的,send()方法根據(jù)數(shù)據(jù)報的目的地址來尋徑以傳送數(shù)據(jù)報。如下代碼所示:

  // 創(chuàng)建一個發(fā)送數(shù)據(jù)的DatagramPacket對象

  DatagramPacket packet = new DatagramPacket(buf, length, address, port);

  // 發(fā)送數(shù)據(jù)報

  socket.send(packet);

  使用DatagramPacket接收數(shù)據(jù)時,會感覺DatagramPacket設(shè)計得過于煩瑣。開發(fā)者只關(guān)心該DatagramPacket能放多少數(shù)據(jù),而DatagramPacket是否采用字節(jié)數(shù)組來存儲數(shù)據(jù)完全不想關(guān)心。但Java要求創(chuàng)建接收數(shù)據(jù)用的DatagramPacket時,必須傳入一個空的字節(jié)數(shù)組,該數(shù)組的長度決定了該DatagramPacket能放多少數(shù)據(jù),這實際上暴露了DatagramPacket的實現(xiàn)細節(jié)。接著DatagramPacket又提供了一個getData()方法,該方法又可以返回Datagram Packet對象里封裝的字節(jié)數(shù)組,該方法更顯得有些多余--如果程序需要獲取DatagramPacket里封裝的字節(jié)數(shù)組,直接訪問傳給 DatagramPacket構(gòu)造器的字節(jié)數(shù)組實參即可,無須調(diào)用該方法。

  當服務器端(也可以是客戶端)接收到一個DatagramPacket對象后,如果想向該數(shù)據(jù)報的發(fā)送者“反饋”一些信息,但由于UDP協(xié)議是面向非連接的,所以接收者并不知道每個數(shù)據(jù)報由誰發(fā)送過來,但程序可以調(diào)用DatagramPacket的如下3個方法來獲取發(fā)送者的IP地址和端口。

  InetAddress getAddress():當程序準備發(fā)送此數(shù)據(jù)報時,該方法返回此數(shù)據(jù)報的目標機器的IP地址;當程序剛接收到一個數(shù)據(jù)報時,該方法返回該數(shù)據(jù)報的發(fā)送主機的IP地址。

  int getPort():當程序準備發(fā)送此數(shù)據(jù)報時,該方法返回此數(shù)據(jù)報的目標機器的端口;當程序剛接收到一個數(shù)據(jù)報時,該方法返回該數(shù)據(jù)報的發(fā)送主機的端口。

  SocketAddress getSocketAddress():當程序準備發(fā)送此數(shù)據(jù)報時,該方法返回此數(shù)據(jù)報的目標SocketAddress;當程序剛接收到一個數(shù)據(jù)報時,該方法返回該數(shù)據(jù)報的發(fā)送主機的SocketAddress。getSocketAddress()方法的返回值是一個SocketAddress對象,該對象實際上就是一個IP地址和一個端口號。也就是說,SocketAddress對象封裝了一個InetAddress對象和一個代表端口的整數(shù),所以使用SocketAddress對象可以同時代表IP地址和端口。

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉