UDP分两次接收数据包 MSG_PEEK
生活随笔
收集整理的這篇文章主要介紹了
UDP分两次接收数据包 MSG_PEEK
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
問題:
今天在測試e_link協(xié)議時,使用SOCK_DGRAM UDP連接服務(wù)器,由于協(xié)議由定長頭部,加數(shù)據(jù)組成,且頭部中包含了數(shù)據(jù)的長度,因此設(shè)計時分兩次進行接收。
先接收頭部,解析出數(shù)據(jù)長度,再次接收數(shù)據(jù)。
但頭部接收正常,但數(shù)據(jù)就讀不到了...
socket(AF_INET, SOCK_DGRAM, 0)connet(ser_addr, addr_len)recv(sock, head, HEADER, 0)data_len = ntohl(head->length)recv(sock, head->data, data_len, 0) //這里就讀不到數(shù)據(jù)了。經(jīng)過查找,原因為協(xié)議棧收到UDP的數(shù)據(jù)報文重組后就放到sock的隊列上(一個skbuff),當讀取部分數(shù)據(jù)后, 這個skbuff就被釋放掉了(不同于TCP,它有的是整個數(shù)據(jù)緩沖隊列)。
目前沒有setsockopt支持 UDP的數(shù)據(jù)讀取,來達到一個數(shù)據(jù)包分多次讀取的字段。
解決方案:
在讀取頭部時,采用如下
recve(sock, head, HEADER, MSG_PEEK)
這樣僅僅是偷窺(peek)一下數(shù)據(jù),得知其數(shù)據(jù)的長度(不會影響 select 以及下一次讀取),然后再一次性讀完。
data_len = ntohl(head->length)
recv(sock, head, HEADER + data_len, 0)
總結(jié)
以上是生活随笔為你收集整理的UDP分两次接收数据包 MSG_PEEK的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 6.项目资源管理总结
- 下一篇: 稻盛和夫《活法》读后感