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

xuht

設計模式在C語言中的應用--讀nginx源碼(轉)

市面上的“設計模式“書籍文章,皆針對Java/C++/C#等面向對象語言,似乎離開了面向對象的種種特性,設計模式就無法實現,沒有用武之地了。


是這樣嗎?設計模式的概念是從建筑領域引入的,本身從沒歧視過面向過程編程語言,它只是對一類問題的普遍解決方案而已。面向對象語言因為有類、多態等特點,使得開發者們容易達到:隱藏細節、封裝變化,而這與設計模式的目的比較一致,所以大師們愛把設計模式與面向對象語言二位一體的使用。然而,存在即合理,C語言直到今日仍然在大型軟件工程中擔綱主角,其種種設計方法其實與我們通常見到的設計模式本質是相同的。例如nginx這個純C語言寫就的的高性能WEB服務器,就有許多地方使用到了市面書籍提到的設計模式。下面通過nginx源碼來看看C語言是怎么做的。當然,UML圖都是我根據代碼意圖所畫,并不準確(C語言真沒法畫UML),只用于方便理解,呵呵。


strategy模式:

該模式用于客戶代碼在“無知”狀態下,可以使用種種不同的實現。下面我們以nginx對網絡IO操作的封裝部分來看看C語言的實現吧。

設計模式就是通過封裝變化來解耦,所以,我們先要找出網絡IO操作的變化點來。nginx是跨平臺的,它會支持linux、freebsd、solaris等操作系統,而每個操作系統的網絡IO操作是不同的,這就是變化點了。

 

所以,nginx首先定義了ngx_os_io_t來封裝這些變化。

 

  1. typedef struct {  
  2.     ngx_recv_pt        recv;  
  3.     ngx_recv_chain_pt  recv_chain;  
  4.     ngx_recv_pt        udp_recv;  
  5.     ngx_send_pt        send;  
  6.     ngx_send_chain_pt  send_chain;  
  7.     ngx_uint_t         flags;  
  8. } ngx_os_io_t;  

這里有五個函數指針(*_pt都是函數指針)和一個變量,用于收發網絡數據,我把它理解為OO中的abstract class(每個ngx_os_io_t定義的變量都會重新實現這五個函數)。

 

擁有函數指針的struct,我通常認為它們是OO中的abstract class,實現它們的文件(一堆函數)要對應到OO上,我則喜歡把它們當做子類來看。對于void*這樣的成員,要根據意圖來看了,通常我會轉換成聚合加繼承的關系。


ngx_io會在相應的ngx_os_specific_init方法中,來策略性的選擇到底使用哪個實現。客戶代碼只需要簡單的調用ngx_io中的方法即可。


adapter模式:

這個模式用以適配接口,通常都是我們已經定義好一種接口了,有一個新的實現卻有著不同的接口,接下來adapter就開始發力了。下面我們仍然以nginx對網絡IO操作的封裝部分來看。

linux平臺下可能存在普通的IO或者異步IO方式。我們在最初已經封裝好ngx_os_io_t接口了,客戶代碼都是這么直接使用的。現在linux實現了異步IO,而它的調用方式與普通的讀寫IO接口完全不同,所以,如果要支持aoi就需要一層adapter來適配ngx_os_io_t,這就是adapter方式了。


上圖中,ngx_os_aio適配了原生的異步IO接口,這樣,用戶代碼仍然像以前一樣,只要直接使用ngx_io中的五個接口方法,當nginx的IO部分支持linux aio后,用戶代碼不需要修改。


bridge橋模式:

橋模式用于將抽象和實現分離,各自都能獨立的變化。下面以nginx的核心概念module舉例,雖然有些牽強,因為nginx的代碼從來沒這么用過:通常都是一個抽象module context只對應著一個實現module來用,但是,畢竟這種結構下還是可以達到抽象與實現分離的目的,橋模式只好對應到這上面了。

nginx是以module的概念貫穿始終的。它有一個基本的抽象層ngx_core_module_t(從意圖上判斷,context有抽象接口的功能,雖然簡單從語法上看不出)。然后,nginx module有三個基本類型,分別是event(處理各種事件模型,如epoll/select等),http(處理各種http協議的事件),mail(處理mail相關的事件)。針對每種類型的module,都有許多個實現,比如event module就有9個實現,這里的每個實現其實也是個子類。


但是,在我們理解橋模式時,這些子類暫時要被看成是event module的實例。代碼中看,像ngx_epoll_module這樣的子類中,還是把一些通用的細節隱藏給ngx_event_core_module來做(管理這個詞更合適)了。從這個角度可以認為,通過context接口,把三個基本module實現分開了。來看看類圖:


nginx自己用時,是以ngx_module_t中的type成員來決定使用哪個實現的。目前的nginx代碼中,如果用了一種接口就一定會指定相應的type。可是實際上,這也可以用來展示橋模式。以事件module為例來看看:


由于UML本就是針對OO語言的,所以以上我畫的類圖都比較牽強,什么是繼承?什么是聚合?在C語言中,往往都是通過幾個函數指針,或者void*指針實現各種封裝和多態。沒有什么語法上的關聯,我就只能從代碼意圖中來判斷了。而代碼意圖這個比較虛,因為不同的角度理解出來都不一樣,所以這個確實不好畫。太靈活了點,我只能從一個便于說明的角度來看,例如:上面的ngx_devpoll_module其實就是一個ngx_module_t,呵呵,但是,實際上它最關心的是ngx_event_actions_t的實現,如果完全根據語法來看,根本說不通的。但從代碼意圖中看,這些module并不關心ngx_module_t,所以我認為,它們只是在實現ngx_event_module_t了。

當然以上只是一家之言,不必當真,如果對nginx源碼有研究的話,歡迎各位拍磚。


客觀的說,C語言確實在封裝上很差,就像nginx,如果我們要開發一個處理http協議的module嵌入進nginx進程,必須了解ngx_http_module里到底做了什么,真沒隱藏啥細節,module開發者們表示很郁悶。上面的這些設計模式,只是做到了代碼上的解藕。如果nginx用C++寫的話,我相信,現在第三方module都能數以萬計了。


原文地址:
http://blog.csdn.net/russell_tao/article/details/7220237

posted on 2012-02-01 18:01 xuht 閱讀(506) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


<2012年2月>
2930311234
567891011
12131415161718
19202122232425
26272829123
45678910

導航

統計

常用鏈接

留言簿

隨筆檔案

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲国产精品一区在线观看不卡| 一本色道久久综合一区| 亚洲欧美视频| 亚洲一区视频在线| 国产精品99久久久久久久vr| 99xxxx成人网| 亚洲永久免费| 久久久久久久久岛国免费| 久久久久综合| 亚洲国产精品福利| 日韩亚洲国产欧美| 亚洲专区欧美专区| 久久精品欧洲| 欧美国产欧美亚州国产日韩mv天天看完整| 欧美成人三级在线| 欧美四级在线观看| 国产一区二区三区免费不卡| 亚洲国产成人porn| 亚洲男人的天堂在线aⅴ视频| 欧美专区在线播放| 亚洲国产精品久久久久久女王| 一区二区三区高清不卡| 欧美中文在线观看国产| 欧美激情四色| 韩国欧美国产1区| 亚洲视频在线观看免费| 久久亚洲精品一区| 在线视频亚洲欧美| 裸体丰满少妇做受久久99精品 | 免费看亚洲片| 一区二区三区日韩欧美精品| 久久电影一区| 欧美午夜美女看片| 亚洲黄色影片| 久久婷婷国产麻豆91天堂| 亚洲精品一品区二品区三品区| 午夜精品视频一区| 欧美日韩国产精品一卡| 亚洲国产精品传媒在线观看| 欧美影院午夜播放| 亚洲人成在线播放网站岛国| 午夜精品久久久久久久久久久久 | 一区二区三区视频在线播放| 久久精品国产69国产精品亚洲| 亚洲成人自拍视频| 性色av一区二区三区在线观看| 欧美不卡激情三级在线观看| 国产亚洲欧美在线| 亚洲女同同性videoxma| 亚洲人成7777| 免费视频亚洲| 亚洲第一色中文字幕| 久久精品国产久精国产一老狼| 99re66热这里只有精品3直播| 免费日韩精品中文字幕视频在线| 好看的日韩av电影| 久久婷婷激情| 久久综合成人精品亚洲另类欧美| 亚洲视频免费| 国产精品日韩高清| 亚洲欧美日本国产有色| 99一区二区| 欧美日韩在线第一页| 99亚洲视频| 日韩视频中午一区| 欧美视频在线看| 亚洲香蕉网站| 国产精品99久久久久久白浆小说| 欧美日韩系列| 欧美一二区视频| 午夜一区二区三视频在线观看| 国产欧美一级| 久久中文精品| 免费亚洲婷婷| 亚洲视频图片小说| 亚洲男女毛片无遮挡| 国产亚洲一区二区三区在线播放| 久久精品在线播放| 久久嫩草精品久久久久| 91久久午夜| 一区二区三区视频在线看| 国产精品入口麻豆原神| 久久aⅴ国产欧美74aaa| 久久视频精品在线| 亚洲精品一区二区三区不| 亚洲日本免费电影| 国产精品v片在线观看不卡| 欧美一区二区福利在线| 久久久免费av| 亚洲天堂网站在线观看视频| 亚洲欧美日韩在线播放| 在线欧美日韩| 中日韩视频在线观看| 国产在线视频不卡二| 亚洲国产精品一区二区三区| 国产精品久久久久久影视| 久久一二三区| 欧美特黄a级高清免费大片a级| 久久久天天操| 欧美日韩亚洲一区二区三区| 欧美一二三区精品| 欧美激情综合| 久久香蕉国产线看观看av| 欧美日本在线| 麻豆亚洲精品| 国产精品视频大全| 亚洲日本中文字幕区| 国产日韩精品视频一区二区三区| 亚洲成人在线网| 国产日本亚洲高清| 日韩视频在线一区二区| 亚洲电影自拍| 欧美伊人久久久久久久久影院| 日韩一二三在线视频播| 久久精品在线播放| 午夜精品视频在线| 欧美日韩精品二区| 欧美国产欧美亚州国产日韩mv天天看完整| 国产精品对白刺激久久久| 欧美国产成人在线| 国产真实乱子伦精品视频| 亚洲女同在线| 欧美视频手机在线| 亚洲国产婷婷| 亚洲国产综合在线| 欧美在线一二三四区| 午夜在线电影亚洲一区| 欧美日韩一级片在线观看| 欧美激情影院| 亚洲高清久久| 久久久夜色精品亚洲| 久久午夜精品| 狠狠色狠狠色综合系列| 欧美一级久久久| 久久精品国产2020观看福利| 国产精品嫩草影院av蜜臀| 一区二区三区www| 亚洲一区精彩视频| 欧美日韩在线观看一区二区| 亚洲人在线视频| 一本大道av伊人久久综合| 欧美va天堂在线| 亚洲激精日韩激精欧美精品| 亚洲精品国产精品国自产在线| 欧美 日韩 国产 一区| 欧美激情一区二区三级高清视频 | 亚洲激情婷婷| 一区二区三区四区在线| 欧美无乱码久久久免费午夜一区| 亚洲精品视频免费| 亚洲一区视频在线| 亚洲卡通欧美制服中文| 99精品免费| 欧美三级在线| 午夜视频一区在线观看| 美女久久网站| a4yy欧美一区二区三区| 欧美天天视频| 亚洲欧美日韩综合国产aⅴ| 久久天堂成人| 亚洲日本成人在线观看| 欧美日韩国产影院| 午夜亚洲伦理| 亚洲黄色成人| 亚洲欧美中文字幕| 亚洲第一黄色| 国产精品久久99| 久久麻豆一区二区| 99国产精品99久久久久久粉嫩| 久久国产精品第一页| 亚洲国产高潮在线观看| 欧美日韩少妇| 久久久久久电影| 亚洲少妇在线| 欧美jizz19hd性欧美| 在线亚洲自拍| 红杏aⅴ成人免费视频| 欧美多人爱爱视频网站| 一区电影在线观看| 玖玖玖国产精品| 亚洲曰本av电影| 亚洲二区视频| 国产专区欧美专区| 欧美人与禽猛交乱配视频| 欧美亚洲一区三区| 亚洲日本激情| 美女精品视频一区| 新狼窝色av性久久久久久| 亚洲国产精品久久久久秋霞影院 | 亚洲一区三区电影在线观看| 欧美在线免费观看亚洲| 国产精品视频xxx| 久久精品欧美| 久久经典综合| 99国产成+人+综合+亚洲欧美| 亚洲日本理论电影| 欧美色欧美亚洲高清在线视频| 亚洲国产欧美日韩精品| 亚洲一级一区| 亚洲国产日韩在线|