成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

TCP字節(jié)流與UDP數(shù)據(jù)報(bào)

網(wǎng)絡(luò) 網(wǎng)絡(luò)管理
“TCP是一種流模式的協(xié)議,UDP是一種數(shù)據(jù)報(bào)模式的協(xié)議”,這句話相信大家對(duì)這句話已經(jīng)耳熟能詳~但是,“流模式”與“數(shù)據(jù)包模式”在編程的時(shí)候有什么區(qū)別呢?以下是我的理解,僅供參考!

“TCP是一種流模式的協(xié)議,UDP是一種數(shù)據(jù)報(bào)模式的協(xié)議”,這句話相信大家對(duì)這句話已經(jīng)耳熟能詳~但是,“流模式”與“數(shù)據(jù)包模式”在編程的時(shí)候有什么區(qū)別呢?以下是我的理解,僅供參考!

1、TCP

打個(gè)比方比喻TCP,你家里有個(gè)蓄水池,你可以里面倒水,蓄水池上有個(gè)龍頭,你可以通過(guò)龍頭將水池里的水放出來(lái),然后用各種各樣的容器裝(杯子、礦泉水瓶、鍋碗瓢盆)接水。

上面的例子中,往水池里倒幾次水和接幾次水是沒(méi)有必然聯(lián)系的,也就是說(shuō)你可以只倒一次水,然后分10次接完。另外,水池里的水接多少就會(huì)少多少;往里面倒多少水,就會(huì)增加多少水,但是不能超過(guò)水池的容量,多出的水會(huì)溢出。

結(jié)合TCP的概念,水池就好比接收緩存,倒水就相當(dāng)于發(fā)送數(shù)據(jù),接水就相當(dāng)于讀取數(shù)據(jù)。好比你通過(guò)TCP連接給另一端發(fā)送數(shù)據(jù),你只調(diào)用了一次 write,發(fā)送了100個(gè)字節(jié),但是對(duì)方可以分10次收完,每次10個(gè)字節(jié);你也可以調(diào)用10次write,每次10個(gè)字節(jié),但是對(duì)方可以一次就收完。(假設(shè)數(shù)據(jù)都能到達(dá))但是,你發(fā)送的數(shù)據(jù)量不能大于對(duì)方的接收緩存(流量控制),如果你硬是要發(fā)送過(guò)量數(shù)據(jù),則對(duì)方的緩存滿了就會(huì)把多出的數(shù)據(jù)丟棄。

2、UDP

UDP和TCP不同,發(fā)送端調(diào)用了幾次write,接收端必須用相同次數(shù)的read讀完。UPD是基于報(bào)文的,在接收的時(shí)候,每次最多只能讀取一個(gè)報(bào)文,報(bào)文和報(bào)文是不會(huì)合并的,如果緩沖區(qū)小于報(bào)文長(zhǎng)度,則多出的部分會(huì)被丟棄。也就說(shuō),如果不指定MSG_PEEK標(biāo)志,每次讀取操作將消耗一個(gè)報(bào)文。

3、為什么

其實(shí),這種不同是由TCP和UDP的特性決定的。TCP是面向連接的,也就是說(shuō),在連接持續(xù)的過(guò)程中,socket中收到的數(shù)據(jù)都是由同一臺(tái)主機(jī)發(fā)出的(劫持什么的不考慮),因此,知道保證數(shù)據(jù)是有序的到達(dá)就行了,至于每次讀取多少數(shù)據(jù)自己看著辦。

而UDP是無(wú)連接的協(xié)議,也就是說(shuō),只要知道接收端的IP和端口,且網(wǎng)絡(luò)是可達(dá)的,任何主機(jī)都可以向接收端發(fā)送數(shù)據(jù)。這時(shí)候,如果一次能讀取超過(guò)一個(gè)報(bào)文的數(shù)據(jù),則會(huì)亂套。比如,主機(jī)A向發(fā)送了報(bào)文P1,主機(jī)B發(fā)送了報(bào)文P2,如果能夠讀取超過(guò)一個(gè)報(bào)文的數(shù)據(jù),那么就會(huì)將P1和P2的數(shù)據(jù)合并在了一起,這樣的數(shù)據(jù)是沒(méi)有意義的。

兩個(gè)協(xié)議其他區(qū)別

TCP(Transmission Control Protocol)傳輸控制協(xié)議:

該協(xié)議主要用于在主機(jī)間建立一個(gè)虛擬連接,以實(shí)現(xiàn)高可靠性的數(shù)據(jù)包交換。IP協(xié)議可以進(jìn)行IP數(shù)據(jù)包的分割和組裝,但是通過(guò)IP協(xié)議并不能清楚地了解到數(shù)據(jù)包是否順利地發(fā)送給目標(biāo)計(jì)算機(jī)。而使用TCP協(xié)議就不同了,在該協(xié)議傳輸模式中在將數(shù)據(jù)包成功發(fā)送給目標(biāo)計(jì)算機(jī)后,TCP會(huì)要求發(fā)送一個(gè)確認(rèn);如果在某個(gè)時(shí)限內(nèi)沒(méi)有收到確認(rèn),那么TCP將重新發(fā)送數(shù)據(jù)包。另外,在傳輸?shù)倪^(guò)程中,如果接收到無(wú)序、丟失以及被破壞的數(shù)據(jù)包,TCP還可以負(fù)責(zé)恢復(fù)。

傳輸控制協(xié)議是一種面向連接的、可靠的、基于字節(jié)流的運(yùn)輸層通信協(xié)議,通常由IETF的RFC793說(shuō)明。在簡(jiǎn)化的計(jì)算機(jī)網(wǎng)絡(luò)OSI模型中,它完成運(yùn)輸層所指定的功能。

UDP (User Datagram Protocol) 用戶數(shù)據(jù)報(bào)協(xié)議:

用戶數(shù)據(jù)報(bào)協(xié)議(UDP)是 ISO參考模型中一種無(wú)連接的傳輸層協(xié)議,提供面向事務(wù)的簡(jiǎn)單不可靠信息傳送服務(wù)。 UDP 協(xié)議基本上是 IP 協(xié)議與上層協(xié)議的接口。 UDP協(xié)議適用端口分辨運(yùn)行在同一臺(tái)設(shè)備上的多個(gè)應(yīng)用程序。

由于大多數(shù)網(wǎng)絡(luò)應(yīng)用程序都在同一臺(tái)機(jī)器上運(yùn)行,計(jì)算機(jī)上必須能夠確保目的地機(jī)器上的軟件程序能從源地址機(jī)器處獲得數(shù)據(jù)包,以及源計(jì)算機(jī)能收到正確的回復(fù)。這是通過(guò)使用UDP 的“端口號(hào)”完成的。

區(qū)別:

1、基于連接與無(wú)連接

TCP---傳輸控制協(xié)議提供的是面向連接、可靠的字節(jié)流服務(wù)。當(dāng)客戶和服務(wù)器彼此交換數(shù)據(jù)前,必須先在雙方之間建立一個(gè)TCP連接,之后才能傳輸數(shù)據(jù)。TCP提供超時(shí)重發(fā),丟棄重復(fù)數(shù)據(jù),檢驗(yàn)數(shù)據(jù),流量控制等功能,保證數(shù)據(jù)能從一端傳到另一端。

每個(gè)數(shù)據(jù)包的傳輸過(guò)程是:先建立鏈路、數(shù)據(jù)傳輸、然后清除鏈路。數(shù)據(jù)包不包含目的地址。受端和發(fā)端不但順序一致,而且內(nèi)容相同。它的可靠性高。

UDP---用戶數(shù)據(jù)報(bào)協(xié)議是面向無(wú)連接的,每個(gè)數(shù)據(jù)包都有完整的源、目的地址及分組編號(hào),各自在網(wǎng)絡(luò)中獨(dú)立傳輸,傳輸中不管其順序,數(shù)據(jù)到達(dá)收端后再進(jìn)行排序組裝,遇有丟失、差錯(cuò)和失序等情況,通過(guò)請(qǐng)求重發(fā)來(lái)解決。它的效率比較高。

是一個(gè)簡(jiǎn)單的面向數(shù)據(jù)報(bào)的運(yùn)輸層協(xié)議。UDP不提供可靠性,它只是把應(yīng)用程序傳給IP層的數(shù)據(jù)報(bào)發(fā)送出去,但是并不能保證它們能到達(dá)目的地。由于UDP在傳輸數(shù)據(jù)報(bào)前不用在客戶和服務(wù)器之間建立一個(gè)連接,且沒(méi)有超時(shí)重發(fā)等機(jī)制,故而傳輸速度很快。

2、對(duì)系統(tǒng)資源的要求(TCP較多,UDP少)

3、UDP程序結(jié)構(gòu)較簡(jiǎn)單

4、流模式與數(shù)據(jù)報(bào)模式

5、TCP保證數(shù)據(jù)正確性,UDP可能丟包,TCP保證數(shù)據(jù)順序,UDP不保證

6、TCP是面可靠的字節(jié)流服務(wù) ,UDP 并不提供對(duì) IP協(xié)議的可靠機(jī)制、流控制以及錯(cuò)誤恢復(fù)功能等。

原文博客:http://www.2cto.com/net/201310/250371.html

責(zé)任編輯:張存 來(lái)源: 博客
相關(guān)推薦

2014-06-27 09:10:23

UDPTCP

2015-01-05 09:56:41

UDPLinux TCP

2010-06-12 15:27:23

UDP協(xié)議

2010-06-13 15:22:16

TCP協(xié)議數(shù)據(jù)報(bào)頭

2014-12-03 14:05:01

TCPUDP

2013-08-01 10:01:02

網(wǎng)絡(luò)協(xié)議TCP協(xié)議UDP協(xié)議

2014-12-04 09:32:08

UDP

2019-06-24 07:34:38

數(shù)據(jù)報(bào)協(xié)議UDPIP

2019-05-28 10:32:29

TCPUDP SYN

2021-12-16 10:08:34

文件字節(jié)流FileInputStFileOutputS

2011-12-19 10:30:17

Java

2010-06-09 14:36:44

TCP與UDP協(xié)議

2019-09-16 08:33:50

TCP協(xié)議UDP

2020-04-01 15:30:19

TCPUDP服務(wù)器

2022-09-02 12:13:22

TCPUDP場(chǎng)景

2010-07-07 10:45:22

TCP UDP協(xié)議

2019-12-31 20:41:39

IPUDPTCP

2020-07-28 08:38:10

TCPUDP協(xié)議

2020-01-13 10:16:53

TCPUDP協(xié)議

2012-01-06 13:58:47

JavaTCP
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 午夜欧美一区二区三区在线播放 | 91最新视频| 欧美福利在线 | 精品国产31久久久久久 | 在线中文字幕av | 精品亚洲一区二区 | 亚洲欧美日韩精品久久亚洲区 | 特黄视频 | 黄色在线观看网址 | 国产精品成人一区二区三区夜夜夜 | 久久国产精99精产国高潮 | 国产成人精品在线 | 婷婷色国产偷v国产偷v小说 | 国产免费xxx | 亚洲欧美中文字幕在线观看 | 久久久久久久综合色一本 | 欧美日韩在线一区二区 | 国产精品久久av | 成人网视频| 男女羞羞网站 | 69视频在线播放 | 91免费版在线观看 | 久久人爽 | 亚洲国产欧美在线 | 久久精品国产99国产 | 欧洲亚洲一区二区三区 | 国产高清久久 | 热99在线| 久久精品 | 久久久免费电影 | 欧美一级在线 | 在线亚洲欧美 | 中文字幕在线观看视频网站 | 99热这里 | 成人免费视频 | 精品久久久久久久久久 | 中文成人在线 | 黄色一级在线播放 | 亚洲一区二区三区在线 | 亚洲激情综合网 | 91色在线 |