關(guān)于粘包,查了一些資料,還是不太清楚。
我的理解是,A 與 B 的連接建立后,socket 將 tcp 字節(jié)流中的非數(shù)據(jù)字段進(jìn)行拆解,并將數(shù)據(jù)部分放入該連接的輸入緩沖區(qū)。當(dāng)有多個(gè) A->B 的包發(fā)來(lái)、且 B 沒(méi)有對(duì)每一條數(shù)據(jù)及時(shí)進(jìn)行處理時(shí),多條信息就會(huì)同時(shí)存在于輸入緩沖區(qū)中,首尾相連。如果數(shù)據(jù)部分沒(méi)有分隔符或能夠標(biāo)識(shí)數(shù)據(jù)長(zhǎng)度的字段,則很有可能出現(xiàn)無(wú)法分割出單條數(shù)據(jù)邊界的情況,從而導(dǎo)致「粘包」。
如果確實(shí)會(huì)出現(xiàn)「粘包」現(xiàn)象,則解決方法是不是應(yīng)該是:
不知道以上的理解是不是有誤?
首先,需要明確什么是tcp中的粘包問(wèn)題(具體可wiki),我這里大致描述下:
tcp粘包就是指在tcp的網(wǎng)絡(luò)編程(當(dāng)然不止tcp,其他粘包也差不多意思)中,由于tcp是流式的,tcp提供給應(yīng)用層的接口,無(wú)法獲知發(fā)送端一次發(fā)了多少數(shù)據(jù),也沒(méi)辦法獲知發(fā)送端發(fā)了多少數(shù)據(jù),就造成下一次數(shù)據(jù)頭緊跟著上上一次數(shù)據(jù)尾,直接提供給應(yīng)用層,應(yīng)用層無(wú)法感知何處是發(fā)送端一次發(fā)送的邊界。
下面說(shuō)一下tcp粘包具體的原因:是發(fā)送端tcp層可能會(huì)對(duì)數(shù)據(jù)封裝成多個(gè)tcp段,不僅如此,還會(huì)對(duì)應(yīng)用層的多次數(shù)據(jù)組成一個(gè)包,比如應(yīng)用層第一次寫(xiě)'A',第二次寫(xiě)'B',第三次寫(xiě)'C',在Tcp層很可能是發(fā)送一個(gè)tcp段,包含的數(shù)據(jù)是'ABC',所以,這樣不管是接收端是否一次讀一個(gè)tcp段,都無(wú)法分辨出哪里是發(fā)送端應(yīng)用層邊界,俗稱(chēng)"粘包"。
好,下面就簡(jiǎn)單說(shuō)一下樓主(主要的錯(cuò)誤也就1點(diǎn)):
圖片描述
如我上面所說(shuō),接收端以如何的方式處理都不是粘包的根本原因,因此,接收端一次讀一個(gè)tcp段也是會(huì)造成粘包現(xiàn)象,從而到處嚴(yán)重的錯(cuò)誤。
那么如何解決粘包:
被采納的答案的兩條建議都是正確的,不過(guò)第一條容易讓人引起誤會(huì),以為tcp可以一次讀出定長(zhǎng)的數(shù)據(jù)。
沒(méi)什么好辦法,就是應(yīng)用層自己設(shè)置協(xié)議解決粘包問(wèn)題,最典型的就是采用協(xié)議頭部和數(shù)據(jù)的方式。注意的是,這里應(yīng)該用狀態(tài)機(jī)實(shí)現(xiàn)接收端的功能,因?yàn)槟悴荒艽_定發(fā)送端發(fā)了完整的頭部,你就一定能收到完整的頭部。
最簡(jiǎn)單的辦法就是設(shè)置8個(gè)字節(jié)的頭部,表示數(shù)據(jù)長(zhǎng)度,接著就是數(shù)據(jù)。
那么發(fā)送端先發(fā)送8個(gè)字節(jié)的一個(gè)數(shù)字,表示接下來(lái)的數(shù)據(jù)大小是多少,接著將數(shù)據(jù)全部發(fā)送過(guò)去。接收端一直接受數(shù)據(jù),一直等到接受滿了8個(gè)數(shù)據(jù),取出來(lái),計(jì)算出大小(假設(shè)為n),接著繼續(xù)讀取n個(gè)字節(jié),就是完整的一個(gè)應(yīng)用層的包了。
北大青鳥(niǎo)APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國(guó)IT技能型緊缺人才,是大數(shù)據(jù)專(zhuān)業(yè)的國(guó)家
北大青鳥(niǎo)中博軟件學(xué)院創(chuàng)立于2003年,作為華東區(qū)著名互聯(lián)網(wǎng)學(xué)院和江蘇省首批服務(wù)外包人才培訓(xùn)基地,中博成功培育了近30000名軟件工程師走向高薪崗位,合作企業(yè)超4
中公教育集團(tuán)創(chuàng)建于1999年,經(jīng)過(guò)二十年潛心發(fā)展,已由一家北大畢業(yè)生自主創(chuàng)業(yè)的信息技術(shù)與教育服務(wù)機(jī)構(gòu),發(fā)展為教育服務(wù)業(yè)的綜合性企業(yè)集團(tuán),成為集合面授教學(xué)培訓(xùn)、網(wǎng)
達(dá)內(nèi)教育集團(tuán)成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機(jī)構(gòu),是中國(guó)一站式人才培養(yǎng)平臺(tái)、一站式人才輸送平臺(tái)。2014年4月3日在美國(guó)成功上市,融資1
曾工作于聯(lián)想擔(dān)任系統(tǒng)開(kāi)發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項(xiàng)目經(jīng)理從事移動(dòng)互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍(lán)懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負(fù)責(zé)iOS教學(xué)及管理工作。
浪潮集團(tuán)項(xiàng)目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺(tái)面向?qū)ο箝_(kāi)發(fā)經(jīng)驗(yàn),技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點(diǎn)難點(diǎn)突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫(kù),具有快速界面開(kāi)發(fā)的能力,對(duì)瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁(yè)制作和網(wǎng)頁(yè)游戲開(kāi)發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開(kāi)發(fā)經(jīng)驗(yàn)。曾經(jīng)歷任德國(guó)Software AG 技術(shù)顧問(wèn),美國(guó)Dachieve 系統(tǒng)架構(gòu)師,美國(guó)AngelEngineers Inc. 系統(tǒng)架構(gòu)師。