在學(xué)習(xí)網(wǎng)絡(luò)編程的時候扔涧,特別是對偏C系的同學(xué)來說囤踩,網(wǎng)絡(luò)編程卷1/卷2和高級環(huán)境編程都是必修課。本系列博客從簡介開始祝峻,對課本重要部分魔吐,結(jié)合自己的理解一一解讀,并對自己在學(xué)習(xí)的過程中碰到的問題進(jìn)行一一記錄莱找。
1.在學(xué)習(xí)軟件編程的時候酬姆,我們第一步是先學(xué)會一門語言,然后實現(xiàn)一個小模塊(封裝成類奥溺,函數(shù)等)辞色,來完成某個具體功能或解決某個具體問題。然后在參與真正項目的時候浮定,往往涉及到大量的封裝相满,模塊與模塊之間的如何設(shè)計,如何使得可擴(kuò)展性更好等又涉及到設(shè)計模式的問題桦卒。但模塊與模塊之間并不一定只在一個進(jìn)程中立美,更不一定在一臺機(jī)器之上,那么當(dāng)我們需要進(jìn)程與進(jìn)程之間進(jìn)行交流方灾,不同網(wǎng)絡(luò)節(jié)點之間需要交流之時建蹄,應(yīng)該如何處理呢。進(jìn)程與進(jìn)程的通信(IPC inter-process communication),推薦UNIX進(jìn)程間通信(卷二)裕偿,我們首先來討論網(wǎng)絡(luò)節(jié)點之間的通信(UNIX網(wǎng)絡(luò)編程卷1)洞慎。這幾本書主要向我們描述了UNIX是如何處理上述問題的,以及常用系統(tǒng)調(diào)用嘿棘,講述了部分原理劲腿,雖然其中有很多接口在實際編程中被封裝或者是被取代,但依舊具有很強(qiáng)的借鑒意義鸟妙。
理解網(wǎng)絡(luò)通信程序的步驟:
1.確定不同網(wǎng)絡(luò)節(jié)點之間程序通信所用到的協(xié)議焦人。
什么是通信協(xié)議?這是個很大的概念圆仔。計算機(jī)四大基礎(chǔ)課之一--《計算機(jī)網(wǎng)絡(luò)》本應(yīng)該是對這個問題的詳盡描述垃瞧。但本科書籍中還是講解太淺蔫劣,以抽象講述為主坪郭,并沒有詳盡展開(以后慢慢講解)。簡單來說脉幢,(參見百科)通信協(xié)議是指雙方實體完成通信或服務(wù)所必須遵循的規(guī)則和約定歪沃。通過通信信道和設(shè)備互連起來的多個不同地理位置的數(shù)據(jù)通信系統(tǒng)嗦锐,要使其能協(xié)同工作實現(xiàn)信息交換和資源共享,它們之間必須具有共同的語言沪曙。交流什么奕污、怎樣交流及何時交流,都必須遵循某種互相都能接受的規(guī)則液走。這個規(guī)則就是通信協(xié)議碳默。
對于剛?cè)腴T的朋友來講,就算看完了剛才的講解缘眶,還是只能有個大致概念嘱根,我舉個不恰當(dāng)?shù)鼙蝗菀桌斫獾睦樱?/p>
通過網(wǎng)絡(luò)傳輸,通信雙方都可以認(rèn)為是基于二進(jìn)制數(shù)據(jù)操作的巷懈。也就是說该抒,發(fā)送方發(fā)送了一連串的二進(jìn)制數(shù)據(jù),通過網(wǎng)絡(luò)顶燕,接收方接收到了這串二進(jìn)制數(shù)據(jù)(例如〈毡!10001001),然后這個8位二進(jìn)制中的每一位或者每幾位代表了某種意思涌攻,具體代表哪些意思欧引,怎么解析,我們事先就可以指定發(fā)送方和接收方都遵循這個規(guī)則癣漆。(當(dāng)然维咸,通信協(xié)議還規(guī)定了很多其他的東西,如通信時間 排序規(guī)則等等惠爽,此處不一一舉出)
2.確定網(wǎng)絡(luò)模型
client-server模型是最常見的模型(但網(wǎng)絡(luò)通信中還有其他模型癌蓖,以后碰到再詳解)。需要明確的是婚肆,服務(wù)器進(jìn)程一般都要寫為守護(hù)進(jìn)程(暫且理解成要在服務(wù)器上長時間運(yùn)行租副,不主動關(guān)閉),在這里我想到了一個插曲:玩c/c++的新手童鞋們經(jīng)常會碰到一個問題,他們經(jīng)常會忘記釋放申請的內(nèi)存導(dǎo)致內(nèi)存泄露较性,然而他們還是一臉無所謂用僧,因為很多書籍中有這么一句話,在這個程序整體運(yùn)行結(jié)束后赞咙,操作系統(tǒng)會自動回收所有相關(guān)資源(包括內(nèi)存)责循,于是他們每次很淡定,不是很在意手動釋放內(nèi)存攀操。大哥院仿。。你這個程序是運(yùn)行一次完了就關(guān)閉了,然而若是寫服務(wù)器端程序(并不會主動關(guān)閉)歹垫,這個內(nèi)存泄露的口子只會越來越大剥汤,最終結(jié)果你懂的~~