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

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>
            日韩一区二区免费看| 欧美日韩国产成人在线| 夜夜嗨av一区二区三区中文字幕| 亚洲欧美日韩在线综合| 日韩视频永久免费| 久久亚洲精品伦理| 久久九九久精品国产免费直播| 欧美日韩高清一区| 亚洲大胆视频| 亚洲第一区在线| 欧美在线观看视频一区二区三区| 亚洲欧美日本国产专区一区| 欧美另类久久久品| 亚洲福利小视频| 亚洲国产你懂的| 玖玖视频精品| 免费在线成人| 亚洲黄色成人久久久| 久久人人爽人人爽| 老鸭窝亚洲一区二区三区| 国产日韩一区二区三区在线播放| 亚洲一区二区三区777| 亚洲一区国产| 国产精品久久久久久五月尺| 中文欧美日韩| 午夜精品久久久久久久99黑人| 欧美日韩国产精品专区| 亚洲精品一区二| 一本久久a久久精品亚洲| 欧美日韩久久不卡| 99在线精品视频在线观看| 亚洲网在线观看| 国产精品久久久久久久久久ktv| 99日韩精品| 欧美一区2区三区4区公司二百 | 欧美mv日韩mv国产网站| 欧美丰满少妇xxxbbb| 亚洲日本国产| 欧美色视频一区| 亚洲性视频h| 久久久久久久久久久一区| 激情五月婷婷综合| 蜜桃久久av一区| 亚洲人成艺术| 午夜欧美视频| 在线播放日韩欧美| 欧美韩国在线| 亚洲欧美电影院| 欧美sm视频| 亚洲一区自拍| 国模私拍一区二区三区| 猛男gaygay欧美视频| av成人动漫| 久久久精品午夜少妇| 亚洲人成网站在线播| 国产精品国产三级欧美二区 | 欧美mv日韩mv国产网站app| 最新精品在线| 久久成人人人人精品欧| 亚洲国产精品福利| 欧美日韩综合在线| 久久精品人人做人人综合| 最新日韩在线| 久久久久成人精品免费播放动漫| 亚洲日本电影| 国产亚洲欧美一区在线观看 | 久久最新视频| 亚洲一区制服诱惑| 亚洲国产99| 久久婷婷人人澡人人喊人人爽| 亚洲精品美女免费| 国产又爽又黄的激情精品视频 | 欧美精品二区| 久久精品国产一区二区三区免费看| 亚洲精品社区| 久久综合伊人77777| 亚洲在线观看免费视频| 亚洲国产精品悠悠久久琪琪| 国产欧美91| 欧美色欧美亚洲另类七区| 久久伊人免费视频| 亚洲欧美日韩区 | 欧美黄色aaaa| 久久久久九九视频| 亚洲男女自偷自拍图片另类| 亚洲精品国精品久久99热一| 国内精品美女av在线播放| 欧美视频网址| 欧美人与禽猛交乱配视频| 美女尤物久久精品| 久久久久久久尹人综合网亚洲| 亚洲免费中文字幕| 亚洲午夜精品久久久久久浪潮| 亚洲日本va午夜在线影院| 欧美激情第五页| 美女精品网站| 蜜臀va亚洲va欧美va天堂| 久久精品国产精品亚洲| 午夜日韩av| 羞羞视频在线观看欧美| 午夜免费电影一区在线观看| 亚洲小说欧美另类社区| 亚洲色图自拍| 这里是久久伊人| 这里只有视频精品| 中文精品视频一区二区在线观看| 亚洲精品一区二区在线| 日韩一二在线观看| 99精品黄色片免费大全| 亚洲图片在线| 午夜精品电影| 久久国产精品久久久| 久久国产精品99久久久久久老狼| 欧美一级在线视频| 久久久精品日韩| 两个人的视频www国产精品| 欧美成年人视频| 亚洲国产va精品久久久不卡综合| 亚洲国产视频一区二区| 99国产精品久久久久久久久久| 日韩视频不卡| 亚洲欧美精品伊人久久| 久久精品国产亚洲精品| 免费观看30秒视频久久| 欧美日韩裸体免费视频| 国产精品一区视频网站| 精品av久久707| 亚洲毛片在线看| 先锋资源久久| 久久一区中文字幕| 亚洲国产综合在线| 亚洲在线免费观看| 久久精视频免费在线久久完整在线看| 久久久久青草大香线综合精品| 欧美a级一区| 国产精品久久久久婷婷| 狠狠久久五月精品中文字幕| 亚洲欧洲综合另类| 亚洲欧美日韩国产一区二区三区 | 亚洲深夜福利| 久久久91精品国产| 欧美精品v日韩精品v国产精品| 国产精品扒开腿做爽爽爽软件| 国产日本精品| 亚洲日本理论电影| 性8sex亚洲区入口| 欧美国产日韩精品免费观看| 一个人看的www久久| 久久午夜av| 国产精品日韩欧美综合| 亚洲国产小视频| 欧美一区二区三区男人的天堂 | 亚洲二区在线| 午夜精品久久久久久久男人的天堂| 久久久久久一区二区三区| 亚洲人午夜精品免费| 久久精品国亚洲| 国产精品99一区| 亚洲精品黄色| 久久久亚洲成人| 一区二区三区四区蜜桃| 免费h精品视频在线播放| 国产欧美日韩免费| 洋洋av久久久久久久一区| 久久综合网hezyo| 一区二区欧美在线观看| 久久亚洲精品中文字幕冲田杏梨 | 国产欧美亚洲精品| 一区二区三区欧美视频| 欧美激情视频在线免费观看 欧美视频免费一 | 欧美激情 亚洲a∨综合| 亚洲新中文字幕| 欧美久久九九| 亚洲人成久久| 女人香蕉久久**毛片精品| 午夜一级久久| 国产精品视频1区| 亚洲一区二区免费| 最新国产精品拍自在线播放| 久久尤物视频| 影音先锋中文字幕一区| 久久精品官网| 欧美一区二区三区久久精品茉莉花 | 黄色国产精品| 久久久久久久999精品视频| 亚洲一区国产视频| 国产精品sm| 亚洲欧美日韩天堂一区二区| 亚洲精品一区二区三区在线观看| 欧美不卡视频一区| 亚洲黄色一区| 亚洲国产小视频| 欧美美女bbbb| 亚洲丝袜av一区| 一区二区激情| 国产精品一区二区在线| 欧美在线精品免播放器视频| 亚洲欧美日韩成人高清在线一区| 国产乱人伦精品一区二区| 欧美在线视频观看|