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

cloud

  C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
  29 Posts :: 1 Stories :: 4 Comments :: 0 Trackbacks

常用鏈接

留言簿(5)

我參與的團隊

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

插件式設計近年來非常流行,其中eclipse起了推波助瀾的作用,提到插件式就會不由自主的想到eclipse。其實插件式設計并不是什么新事物,早在幾十年前就有了。像X Server就是基于插件式設計的,除了核心功能外,它所有的擴展功能和設備驅動都是以插件方式加入進來的。

  基于插件的設計好處很多:把擴展功能從框架中剝離出來,降低了框架的復雜度,讓框架更容易實現。擴展功能與框架以一種很松的方式耦合,兩者在保持接口不變的情況下,可以獨立變化和發布。公開插件接口,讓第三方有機會擴展應用程序的功能,有財大家一起發。另外,還可以讓開源與閉源共存于一套軟件,你的插件是開源還是閉源,完全由你自己決定。

  基于插件設計并不神秘,相反它比起一團泥的設計更簡單,更容易理解。各種基于插件設計的架構都有自己的特色,但從總體架構上看,其模型都大同小異。這里我們介紹一個簡單的模型,并給出幾個實例,希望對新手有所啟發。

  1. 基本架構

plugin.jpg

  插件式設計的應用程序,基本上可以用上圖來表示。當然,此圖是一種較高層次的表示,實際的設計會更復雜一些。我們在這里為了闡述方便,不用故意搞得那么復雜。

  應用程序由應用程序框架、插件接口、插件和公共函數庫四部分組成。

  應用程序框架負責應用程序的整體運作,它清楚程序整個流程,但并不知道每個過程具體要做什么。它在適當的時候調用一些插件,來完成真正的功能。

  插件接口是一個協議,可能用IDL描述,可能是頭文件,也可能一段文字說明。插件按照這個協議實現出來,就可以加入到應用程序中來。當然,對于復雜的系統,插件接口可能有多個,各自具有獨立的功能。

  插件是完成實際功能的實體,實現了要求的插件接口。盡管實現什么以及怎么實現,完全是插件自己的自由。在實際情況來,一般還是有些限制,因為插件接口本身可能就是一個限制。如,實現編譯功能的插件,自然不能實現成一個聊天功能的插件。

  公共函數庫是一組函數或者類,應用程序框架和插件都可以調用。它通常是一個獨立的動態庫(DLL)。應用程序框架本身是公用的,是代碼復用的一種方式。但并不是所有可復用代碼都可以放在框架中,特別是插件會用到的公共代碼,那會造成插件對框架的依賴。把這些公共代碼提取到一個獨立的庫中,是一種好的方法。

  另外,值得補充說明一下的是插件接口。插件接口通常有兩種:

  通用插件接口:這一類插件接口是通用的,你無法從接口函數看出這個插件的功能。它的接口函數通常有這些函數:

  init : 用于初始化插件,通常在插件被加載時調用。

  deinit:用于反初始化插件,通常在插件被卸載時調用。

  run:讓插件起動。

  stop:讓插件停止。

  至于插件要完成什么功能,要插到哪里,在init函數里決定,它調用公共函數庫里的函數把自己注冊到框架中某個位置。

  專用插件接口:這一類插件接口是專用的,看到它的接口函數說明,你就可以大致了解它的功能了。

  加入插件的方式通常采用配置信息來實現,配置信息可以是注冊表,也可以配置文件。也可以動態注冊進來,或者把插件放到指定的位置。

  下面我們來看幾個實例:

  2. 桌面設計

  最近一段時間完成了桌面模塊的設計和實現。按照以往的經驗,桌面模塊通常是變化最多的一個模塊,SPEC總是在不斷的調整的效果,不同客戶要求實現具有個性化的桌面,直到產品快發布了,桌面的SPEC還在不停的修改。另外,在智能手機中,桌面占有特殊的地位,很多東西都可能往桌面里塞,桌面不但是各種功能的大雜燴,還是一些系統消息的中轉站。

  這個任務比較棘手,所以在設計時就分外小心。首先想到的就是采用插件式設計,把外圍功能獨立出來,盡量簡化框架的實現。

  插件:每一個最小功能單元都是一個插件,它可以是可見的,也可以是不可的,也可以是動態變化的。比如時間、電池電量、網絡連接、信號強弱、新事件(如SMS、MMS、EMAL、ALARM和未接電話等)、應用程序快捷方式、左右操作按鈕和其它處理系統事件的功能單元。每個插件都用一個.desktop來描述,這是遵循freedesktop.org的標準的。

  桌面框架包括:狀態欄、開始菜單、操作欄、桌面區、事件管理器和主題管理器。而狀態欄、開始菜單、操作欄、桌面區和事件管理器都是容器,容納各種插件。對于可見的插件,可以有自己的表現方式,也可以采用通用的表現方式。

  公共函數庫:一些抽象的類、實現插件的輔助類以及其它一些可能被公用的類。

  插件接口:對于不可見的插件要求實現事件處理功能,可見的插件還要求實現繪制功能。

  3. 模擬器設計

  一個同事負責設計另外一個平臺的PC模擬環境設計。在我的建議下,他對架構作了調整。調整后的架構非常簡單,也可以認為是插件式的設計,它由下面幾部分組成:

  應用程序框架:負責模擬器基本功能,如模擬鍵盤和顯示設備、換膚功能等。

  插件:就是被模擬的平臺,如microwindow及相應的手機應用程序。盡管運行時通常只有一個插件運行,這樣做仍然有意義,如果要換成minigui或者其它平臺時,模擬器不需要作任何修改。

  公共函數庫:它由應用程序框架初始化一些信息和回調函數,然后供插件(即microwindow)調用,插件利用它來實現顯示和輸入等驅動程序。

  插件接口:如起動和停止模擬平臺等。

  4. GIMP

  GIMP是一個功能強大的圖形圖像編輯器,典型的基于插件式的設計,在《unix編程藝術》中,作為插件式設計示例介紹過。

  應用程序框架:GUI

  插件:完成圖像的各種轉換和處理功能,如模糊、去斑和色彩調整等。

  公共函數庫:放在libgimp.so里。

  插件接口:對GIMP感興趣的朋友,可以到官方網站上去閱讀更多的文檔。
posted on 2007-06-08 16:01 cloud 閱讀(1414) 評論(0)  編輯 收藏 引用

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


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久er精品视频| 亚洲黄色成人久久久| 亚洲在线不卡| 国产人妖伪娘一区91| 久久久久国产精品一区三寸| 午夜欧美不卡精品aaaaa| 狠狠综合久久av一区二区小说 | 黄色国产精品| 欧美成人精品1314www| 欧美日韩成人一区| 新狼窝色av性久久久久久| 香蕉久久a毛片| 亚洲精品美女91| 亚洲在线观看| 伊人精品久久久久7777| 亚洲精品久久久久久下一站| 国产精品一区二区女厕厕| 蜜臀av国产精品久久久久| 欧美理论电影在线播放| 性欧美大战久久久久久久免费观看| 久久成人人人人精品欧| 亚洲精品在线看| 亚洲一区二区日本| 在线成人激情视频| 一区二区电影免费在线观看| 韩国精品在线观看| 一本一本久久a久久精品牛牛影视| 国产精品日本精品| 亚洲国产精品一区二区久| 国产美女扒开尿口久久久| 亚洲电影免费观看高清完整版| 国产精品久久777777毛茸茸| 欧美电影免费观看大全| 国产视频在线观看一区二区| 亚洲精品偷拍| 在线观看欧美日韩国产| 亚洲一区在线播放| 一区二区三区日韩精品| 久久人人精品| 久久高清福利视频| 国产精品a级| 亚洲黄色三级| 亚洲国内高清视频| 久久精品国产欧美激情| 香蕉av福利精品导航| 欧美精品免费播放| 欧美激情五月| 亚洲国产免费| 久久久青草青青国产亚洲免观| 性欧美长视频| 国产精品毛片一区二区三区| 亚洲精品欧美精品| 日韩视频免费观看高清在线视频 | 中文一区字幕| 999在线观看精品免费不卡网站| 久久久久国色av免费观看性色| 午夜亚洲精品| 国产精品毛片va一区二区三区 | 亚洲精品综合| 亚洲精品裸体| 欧美激情精品久久久六区热门 | 午夜精品视频在线| 午夜电影亚洲| 国产精品羞羞答答| 亚洲在线一区二区三区| 亚洲欧美美女| 国产女优一区| 久久国产精品99国产| 久久综合国产精品| 在线欧美日韩国产| 欧美福利视频一区| 亚洲精品免费观看| 亚洲一区二区少妇| 国产精品久久久久久久久借妻| 中文精品99久久国产香蕉| 亚洲欧美一区二区三区久久 | 免费观看成人鲁鲁鲁鲁鲁视频 | 一本色道久久综合亚洲91| 欧美另类综合| 亚洲一区综合| 久久天天躁狠狠躁夜夜爽蜜月| 在线精品国精品国产尤物884a| 巨乳诱惑日韩免费av| 亚洲精品一品区二品区三品区| 亚洲天堂激情| 国产亚洲福利一区| 免费成人激情视频| 一区二区三区蜜桃网| 久久九九全国免费精品观看| 亚洲成人自拍视频| 欧美日韩一级大片网址| 午夜精品av| 欧美成人精品一区二区三区| 亚洲美女精品成人在线视频| 国产精品久久久久久久7电影| 欧美一级片在线播放| 亚洲福利视频网站| 午夜欧美大片免费观看| 亚洲国产精品久久久久秋霞影院| 欧美日韩精品| 久久久噜噜噜久久中文字免| 亚洲美女性视频| 老司机亚洲精品| 亚洲午夜一区二区| 在线观看视频亚洲| 国产精品久久久久天堂| 免费成人小视频| 午夜久久黄色| 日韩亚洲视频| 欧美激情精品久久久久久黑人 | 亚洲卡通欧美制服中文| 国产精品专区h在线观看| 欧美a级一区| 欧美在线免费观看亚洲| av成人免费在线观看| 免费观看久久久4p| 欧美主播一区二区三区美女 久久精品人| 伊人成年综合电影网| 国产精品免费区二区三区观看| 嫩草国产精品入口| 久久九九热re6这里有精品| 在线亚洲一区观看| 亚洲精品一区二区网址| 欧美二区在线观看| 麻豆精品国产91久久久久久| 性欧美1819性猛交| 亚洲欧美精品在线| 亚洲香蕉在线观看| 99天天综合性| 亚洲日本电影| 91久久久一线二线三线品牌| 在线播放豆国产99亚洲| 国产一区二区三区日韩欧美| 国产精品夜夜夜| 国产精品美女久久久浪潮软件| 欧美人妖在线观看| 欧美日韩a区| 欧美国产在线视频| 欧美激情综合| 欧美精品日本| 欧美日韩视频在线一区二区| 欧美另类视频| 欧美视频日韩视频| 欧美小视频在线| 国产精品极品美女粉嫩高清在线| 欧美日韩午夜视频在线观看| 欧美日韩一区成人| 欧美小视频在线| 国产精品都在这里| 国产精品视频免费在线观看| 国产欧美一区二区精品性色| 国产欧美一区二区三区在线看蜜臀| 国产日产欧美一区| 韩国三级在线一区| 亚洲经典在线看| 99国产精品久久久| 亚洲在线国产日韩欧美| 欧美伊人久久大香线蕉综合69| 久久精品99国产精品| 蜜臀av国产精品久久久久| 亚洲国产精品999| 亚洲伦理一区| 亚洲女性裸体视频| 久久九九电影| 欧美精品色网| 国产日本精品| 亚洲激情小视频| 亚洲在线观看视频网站| 久久国产欧美精品| 亚洲高清网站| 亚洲女人小视频在线观看| 久久久精品日韩欧美| 欧美日韩不卡| 国产亚洲成精品久久| 亚洲精品系列| 久久精品伊人| 亚洲老板91色精品久久| 久久xxxx精品视频| 欧美精品一区二区三区视频| 国产欧美一区二区三区视频 | 国产在线不卡精品| 亚洲精选成人| 久久久精品一区二区三区| 亚洲欧洲日本专区| 久久国产精品99国产| 欧美日韩一区二区精品| 激情亚洲一区二区三区四区| 亚洲无玛一区| 亚洲第一在线综合在线| 欧美一级欧美一级在线播放| 欧美日韩国产bt| 在线免费不卡视频| 欧美一级视频| 一区二区三区欧美在线| 女同性一区二区三区人了人一| 国产一区二区三区黄视频| 亚洲午夜激情网页| 亚洲欧洲综合另类| 久久亚洲私人国产精品va| 国产欧美日韩激情|