青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Creative Commons License
本Blog采用 知識共享署名-非商業性使用-禁止演繹 3.0 Unported許可協議 進行許可。 —— Fox <游戲人生>

游戲人生

游戲人生 != ( 人生 == 游戲 )
站點遷移至:http://www.yulefox.com。請訂閱本博的朋友將RSS修改為http://feeds.feedburner.com/yulefox
posts - 62, comments - 508, trackbacks - 0, articles - 7

ACE: Socket封裝(01)

Posted on 2009-09-01 14:22 Fox 閱讀(3917) 評論(3)  編輯 收藏 引用 所屬分類: T技術碎語

本文同步自游戲人生

o *__ 序 __* o

在閱讀ACE代碼和C++NPv1, v2, APG的時候,我意識到一個問題:雖然稍有C++和網絡基礎的同學都可以讀懂ACE,但如果你對OS(五大管理模塊都包含在內)、TCP/IP、C++、Design Patterns了解越多,你就越能體會ACE為什么需要這么龐雜,雖然它不夠完美(但至少我還沒有資格來批評這一點,我現在最常想做的一個動作就是五體投地)。

而且我隱約感覺到,我現在所寫的很多東西在以后(對于有些人或許就是現在)看來會相當不深刻、相當不嚴謹,但對于一段學習歷程,這個過程是必然的、必需的。

在C++NPv1中,Douglas C. Schmidt把原始socket及其API的缺陷有些妖魔化了,比如一段加上注釋、空行在內的35行的代碼,被指出有10處錯誤之多。這就像很多其他語言的倡導者或反傳統C/C++指針者在批評指針時的說法一樣。長期使用原始socket和指針的同學對此感覺很不舒服,何況socket API提供了大量錯誤檢測的接口,至多是不夠友好罷了。你好就好了,沒必要抓住別人一頓痛批吧,『本是同根生,相煎何太急』。

雖然Solaris、Linux的很多版本及Windows對起源于Berkeley的socket API進行了重寫,但不可否認,由于歷史原因和POSIX標準的存在,對于使用者而言,我們可以無視這些API的實現差異。只是一旦我們從socket通信擴展到其他IPC通信的話,就需要正視各種I/O細節的差異了。

由于UNIX中,對于socket, file, pipe, device的大多數操作,描述符都是通用的(這一點,OS上面講的更清楚些)。而Windows中,句柄大多不能互換(socket對于MS來說是舶來品)。系統和標準的不一致導致地址、協議和API的混雜甚至混亂。

UNIX下的描述符和Windows的句柄可以看作是同一個概念,只是應用環境不一樣,所描述的內容也時常不一樣,再簡單了說,它們都是一個整型的ID。

ACE的源碼中使用了大量預處理指令,尤其在跨平臺/編譯環境的部分更加明顯。鑒于C/C++標準的博大胸懷,有些指令需要閱讀相關編譯器提供的幫助文檔:

o #pragma: GCC, MSVC

o #define (#, #@, ##) : GCC, MSVC

其中有若干代碼文件以.inl為后綴,里面是對部分函數的內聯實現,以使代碼結構看上去更加簡潔。如果確定使用內聯函數的話,*.inl將被包含于*.h的最后,如果不使用,則像*.h一樣,包含于*.cpp的頭部。

ACE采用doxygen輸出文檔,在閱讀代碼注釋時能夠感受到差異,但基本不會影響閱讀。

o * __ 關于第3章(C++NPv1)__ * o

ACE抽象的地址類ACE_Addr擁有ACE_DEV_Addr, ACE_FILE_Addr, ACE_INET_Addr, ACE_SPIPE_Addr, ACE_UNIX_Addr五個子類。對于狹義上的網絡通信(TCP/IP)而言,ACE_INET_Addr對應于我們熟悉的sockaddr_in。

ACE_IPC_SAP是IPC(interprocess communication)I/O操作類的root類。

從編碼的角度看,這個類漂亮的地方在于示例了抽象類的另一種實現方式。

一提到抽象類,大多數人的第一反應是pure virtual function。當一個基類確定需要使用virtual function時,這是一個不錯的選擇。但我們都知道虛擬函數有開銷。而且對于一個結構簡單的抽象基類和其繼承子類(尤其是大量使用時),一個虛函數表帶來的開銷會讓整個設計顯得十分蹩腳。

我們都知道如何強制讓一個類無法使用default constructor(protected)。如果對基類使用該方法,僅使子類具有public的default constructor,這就達到了定義抽象基類的效果。

virtual destructor的意義在于防止delete父類指針(指向子類對象)時未調用子類destructor。在此例中,為避免這種情況,同樣將destructor聲明為protected即可。

從設計實現的角度看,相較于socket API,ACE_IPC_SAP的子類ACE_SOCK提供了編譯時對句柄合法性的檢測。

從邏輯功能層面劃分,socket有三種角色:

o active connection role (connector):主動連接

o passive connection role (acceptor):被動連接

o communication role (stream):數據通信

但socket API畢竟不是OOD出來的,對于一個socket描述符,也完全沒有必要去限制其擔負的功能,更不可能搞成三種不同的socket。而OOD的ACE則可以輕易實現對socket對象及其操作的封裝。

工廠類ACE_SOCK_Connector是一個主動創建通信端的工廠類。socket API中的connect接口只是為一個socket建立與其它peer的網絡連接,而不產生新的socket實例,也不依賴于任何其它socket。同樣,ACE_SOCK_Connector只是為一個ACE_SOCK_Stream對象(對用于數據通信的socket的封裝)連接到ACE_Addr(對struct sockaddr的封裝)提供接口,也不含對ACE_SOCK_Stream對象的其它操作。

工廠類ACE_SOCK_Acceptor是一個被動創建通信端的工廠類。當監聽到新的網絡連接后,為該連接初始化一個ACE_SOCK_Stream對象。和connector不同的是,acceptor依賴于一個已經存在的充當監聽功能的socket句柄(ACE_SOCK),因此,ACE_SOCK_Acceptor是ACE_SOCK的一個子類。

ACE_SOCK_Stream是只負有通信傳輸功能的socket,對應connection-oriented的TCP通信格式stream,和UDP的CE_SOCK_CODgram相呼應。ACE_SOCK_Stream只是socket的通信載體,在兩個工廠ACE_SOCK_Connector和ACE_SOCK_Acceptor中初始化。這樣一個類除支持最基本的數據發送(send)和接收(recv)和阻塞(blocking)、非阻塞(nonblocking)及定時(timed)的I/O模式外,還支持分散讀取(scatter-read)和集中寫入(gather-write)。

對于一個簡單的『網絡課程作業:寫一個有連接的IM小程序』,上面這些內容已經足夠了。當然即使使用對應的幾個socket API也已經足夠了。但我們顯然更加關心如此龐大的一個庫,是如何解決復雜的網絡應用的,我尤其關心的是多線程并發如何更好的處理。

所以,我準備跑到第8、9章了。

Feedback

# re: ACE: Socket封裝(01)  回復  更多評論   

2009-09-01 16:10 by 99書城
很好啊~~

# re: ACE: Socket封裝(01)  回復  更多評論   

2009-09-01 17:15 by yleesun
不錯,很真實

# re: ACE: Socket封裝(01)  回復  更多評論   

2012-08-17 22:14 by swiss replica watches
清爽的很
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产亚洲精品激情久久| 国产日韩欧美a| 亚洲人成免费| 亚洲国产综合91精品麻豆| 亚洲欧美日韩久久精品 | 欧美肥婆在线| 欧美高清在线| 中文在线不卡| 亚洲欧美日韩另类| 亚洲国产第一页| 99re这里只有精品6| 欧美日韩一区在线观看| 亚洲一区二区三区四区中文 | 99国产精品视频免费观看| 国产精品久线观看视频| 久久国产精品色婷婷| 久久久久九九视频| 久久婷婷国产综合精品青草| 欧美亚洲三级| 久热精品在线| 亚洲男人第一av网站| 久久国产精品99国产精| 日韩视频在线一区二区| 亚洲自拍16p| 亚洲国产导航| 亚洲在线视频免费观看| 亚洲日本中文字幕| 亚洲欧美日韩区| 亚洲啪啪91| 亚洲欧美久久久| 亚洲欧洲日韩女同| 欧美一区二区日韩一区二区| 日韩一本二本av| 久久国产欧美日韩精品| 亚洲午夜精品久久| 久久偷窥视频| 久久国产色av| 国产精品成人一区二区艾草| 免费观看成人鲁鲁鲁鲁鲁视频| 国产精品成人播放| 亚洲福利视频二区| 国语自产精品视频在线看一大j8 | 欧美人与禽猛交乱配| 久久九九久精品国产免费直播| 欧美日本精品| 欧美承认网站| 伊人成人开心激情综合网| 亚洲自拍电影| 亚洲在线视频| 日韩午夜免费视频| 久热精品视频在线观看| 一区二区三区国产精品| 久久综合亚洲社区| 99ri日韩精品视频| 国产日韩欧美自拍| 亚洲宅男天堂在线观看无病毒| 亚洲免费观看视频| 蜜月aⅴ免费一区二区三区| 美女尤物久久精品| 在线观看91精品国产麻豆| 欧美在线啊v一区| 久久精品一区二区三区不卡| 国产精品日韩二区| 亚洲欧美自拍偷拍| 欧美在线网址| 国外成人性视频| 久久手机免费观看| 欧美成人午夜免费视在线看片| 一色屋精品视频在线观看网站| 久久精品亚洲一区二区| 免费观看成人| 亚洲美女少妇无套啪啪呻吟| 欧美精品在线免费播放| 亚洲国产一区在线观看| 夜夜狂射影院欧美极品| 欧美日韩免费观看一区三区| 亚洲免费av片| 午夜精品福利一区二区蜜股av| 欧美性猛交视频| 在线一区二区三区四区五区| 亚洲一区二区免费| 国产一区二区久久| 美国十次了思思久久精品导航| 亚洲国产精品成人va在线观看| 99天天综合性| 国产无遮挡一区二区三区毛片日本| 欧美亚洲一区在线| 欧美成人一区二区三区片免费| 亚洲美女黄色| 国产欧美一区二区三区另类精品| 久久国产精品亚洲va麻豆| 亚洲国产一区二区精品专区| 亚洲综合日韩中文字幕v在线| 国产精品美女一区二区在线观看| 亚洲欧美日本国产专区一区| 开元免费观看欧美电视剧网站| 亚洲精品在线一区二区| 国产欧美精品va在线观看| 亚洲电影网站| aa级大片欧美| 久久久蜜桃一区二区人| 亚洲免费福利视频| 国产亚洲va综合人人澡精品| 欧美黄色视屏| 性做久久久久久| 亚洲精品小视频| 蜜桃av一区二区| 亚洲欧美综合国产精品一区| 亚洲国产高潮在线观看| 国产麻豆成人精品| 欧美精品久久一区| 久久久久久久性| 午夜精品久久久久久久99黑人| 欧美99在线视频观看| 亚洲男女自偷自拍图片另类| 亚洲激情一区二区| 国产一区二区精品丝袜| 国产精品红桃| 欧美日韩dvd在线观看| 久久婷婷成人综合色| 亚洲欧美日韩在线观看a三区| 亚洲一本大道在线| 欧美午夜免费影院| 蜜桃av综合| 午夜视频一区在线观看| 亚洲欧洲一区二区三区久久| 巨乳诱惑日韩免费av| 欧美在线视频导航| 亚洲自拍偷拍网址| 亚洲在线一区| 亚洲无亚洲人成网站77777| 亚洲理论在线观看| 亚洲人成在线观看| 最新国产成人在线观看| 在线欧美视频| 在线免费观看日本欧美| 韩日欧美一区二区三区| 国产一区二区高清视频| 国产亚洲欧美另类一区二区三区| 国产精品欧美经典| 国产女人精品视频| 国产亚洲激情| 极品少妇一区二区三区精品视频| 国产亚洲在线| 狠狠色综合一区二区| 韩国一区电影| 亚洲大胆女人| 欧美~级网站不卡| 好吊日精品视频| 国产亚洲免费的视频看| 国产欧美亚洲视频| 国产欧美日韩精品a在线观看| 国产九色精品成人porny| 国产亚洲a∨片在线观看| 永久久久久久| 亚洲理论在线| 亚洲一品av免费观看| 午夜日本精品| 另类激情亚洲| 亚洲激情成人在线| 亚洲深夜av| 久久国产天堂福利天堂| 美国三级日本三级久久99| 欧美精品国产一区| 欧美婷婷久久| 狠狠色狠狠色综合| 尤物精品国产第一福利三区| 亚洲国产成人高清精品| 亚洲一区二区精品在线观看| 久久精品观看| 亚洲日本免费电影| 亚洲宅男天堂在线观看无病毒| 久久精品亚洲热| 欧美丝袜一区二区三区| 一区二区三区在线观看国产| 亚洲精品视频免费在线观看| 亚洲一区精品视频| 久久午夜精品| 亚洲国产精品成人综合| 一本一本久久| 麻豆精品精华液| 国产精品推荐精品| 亚洲伦理在线观看| 久久九九久精品国产免费直播| 亚洲激情电影在线| 久久国产欧美| 国产精品一区二区久久精品| 亚洲国产精品一区二区第一页 | 亚洲国产精品www| 亚洲一区视频在线| 欧美福利视频在线| 亚洲综合色激情五月| 欧美高清在线一区| 激情综合电影网| 欧美一区二区三区日韩| 亚洲人成网站在线观看播放| 久久精品国产精品亚洲精品| 国产精品久久久久久久久借妻| 亚洲国产精品一区在线观看不卡| 欧美在线观看一二区|