socket是網(wǎng)絡(luò)編程的基礎(chǔ),本文用打電話來(lái)類比socket通信中建立TCP連接的過程。
socket函數(shù),表示你買了或者借了一部手機(jī)。
bind函數(shù),告訴別人你的手機(jī)號(hào)碼,讓他們給你打電話。
listen函數(shù),打開手機(jī)的鈴聲,而不是靜音,這樣有電話時(shí)可以立馬反應(yīng)。listen函數(shù)的第二個(gè)參數(shù),最大連接數(shù),表示最多有幾個(gè)人可以同時(shí)撥打你的號(hào)碼。不過我們的手機(jī),最多只能有一個(gè)人打進(jìn)來(lái),要不然就提示占線。
connect函數(shù),你的朋友知道了你的號(hào)碼,通過這個(gè)號(hào)碼來(lái)聯(lián)系你。在他等待你回應(yīng)的時(shí)候,不能做其他事情,所以connect函數(shù)是阻塞的。
accept函數(shù),你聽到了電話鈴聲,接電話,accept it!然后“喂”一聲,你的朋友聽到你的回應(yīng),知道電話已經(jīng)打進(jìn)去了。至此,一個(gè)TCP連接建立了。
read/write函數(shù),連接建立后,TCP的兩端可以互相收發(fā)消息,這時(shí)候的連接是全雙工的。對(duì)應(yīng)打電話中的電話煲。
close函數(shù),通話完畢,一方說(shuō)“我掛了”,另一方回應(yīng)"你掛吧",然后將連接終止。實(shí)際的close(sockfd)有些不同,它不止是終止連接,還把手機(jī)也歸還,不在占有這部手機(jī),就當(dāng)是公用電話吧。
注意到,上述連接是阻塞的,你一次只能響應(yīng)一個(gè)用戶的連接請(qǐng)求,但在實(shí)際網(wǎng)絡(luò)編程中,一個(gè)服務(wù)器服務(wù)于多個(gè)客戶,上述方案也就行不通了,怎么辦?想一想1860,移動(dòng)的聲訊服務(wù)臺(tái),也是只有一個(gè)號(hào)碼,它怎么能同時(shí)服務(wù)那么多人呢?可以這樣理解,在你打電話到1860時(shí),總服務(wù)臺(tái)會(huì)讓一個(gè)接線員來(lái)為你服務(wù),而它自己卻繼續(xù)監(jiān)聽有沒有新的電話接入。在網(wǎng)絡(luò)編程中,這個(gè)過程類似于fork一個(gè)子進(jìn)程,建立實(shí)際的通信連接,而主進(jìn)程繼續(xù)監(jiān)聽。1860的接線員是有限的,所以當(dāng)連接的人數(shù)達(dá)到上線時(shí),它會(huì)放首歌給你聽,忙等待,直到有新的空閑接線員為止。
實(shí)際網(wǎng)絡(luò)編程中,處理并發(fā)的方式還有select/poll/epoll等。
下面是一個(gè)實(shí)際的socket通信過程:
posted on 2008-10-26 17:09
ronliu 閱讀(4080)
評(píng)論(4) 編輯 收藏 引用 所屬分類:
Linux 、
Net Programming