TCP/IP学习笔记-Qt中的ReuseAddressHint以及SO_REUSEADDR,以为组播常用场景分析
最近在看一個局域網聊天的源碼(Qt做的)
發現大佬用了這樣的代碼:
udpSocket->bind(port, QUdpSocket::ShareAddress | QUdpSocket::ReuseAddressHint);根據文檔可以知道這個ShareAddress,允許其他的服務(進程)去綁定這個IP和端口,而這個ReuseAddressHint為失敗后立即使用他與SO_REUSEADDR一毛一樣(這是官方文檔上說的,不是我說的)
下面是來自一個大佬的博文的信息。
Q:編寫?TCP/SOCK_STREAM?服務程序時,SO_REUSEADDR到底什么意思?
A:這個套接字選項通知內核,如果端口忙,但TCP狀態位于?TIME_WAIT?,可以重用端口。如果端口忙,而TCP狀態位于其他狀態,重用端口時依舊得到一個錯誤信息,指明"地址已經使用中"。如果你的服務程序停止后想立即重啟,而新套接字依舊使用同一端口,此時SO_REUSEADDR?選項非常有用。必須意識到,此時任何非期望數據到達,都可能導致服務程序反應混亂,不過這只是一種可能,事實上很不可能。
【備注】一個套接字由相關五元組構成,協議、本地地址、本地端口、遠程地址、遠程端口。SO_REUSEADDR?僅僅表示可以重用本地本地地址、本地端口,整個相關五元組還是唯一確定的。所以,重啟后的服務程序有可能收到非期望數據。必須慎重使用SO_REUSEADDR?選項。
下面來說下組播,我直接總結下百度上看到的資料,
組播又名多播,就是指向某一個組發送,特定的幾個人。
這個概念真是SO happy啊。。。。
比如說局域網聊天, 我多開了幾個程序,那么就可以用組播來搞。(在本地回環中,的確可以實現【每一個程序都收到了消息】)
明天,我也將做一個簡易版的udp組播聊天軟件,并加上了tcp文件傳輸。
睡覺了!!!!
總結
以上是生活随笔為你收集整理的TCP/IP学习笔记-Qt中的ReuseAddressHint以及SO_REUSEADDR,以为组播常用场景分析的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: java题-java运行时异常与一般异常
- 下一篇: Qt工作笔记-QSort的基本使用