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

隨筆 - 119  文章 - 290  trackbacks - 0

博客搬家了哦,請移步
叫我abc

常用鏈接

留言簿(12)

隨筆分類

我的博客

搜索

  •  

積分與排名

  • 積分 - 305651
  • 排名 - 84

最新評論

閱讀排行榜

首先說,接口是一個定義極多的詞匯,每一本書使用接口這個詞的時候都有不同的語境,代表不同的意思。
1,類的一個public方法/函。
2,一個只擁有純虛函數的類,一般用interface定義。
3,程序操作界面。
在《UNIX編程藝術》一書中,接口是“程序同人類用戶以及其他程序通訊方法的總和”。通俗的說,接口是程序獲得輸入數據和命令的來源。具體有這些情形,程序的執行參數,或者基于IPC的一套應用協議/數據格式,或者是人類使用的CLI或者GUI所有效的操作。與此相應的是,程序的實際功能被稱為接口功能。不能很好的理解該書對接口的定義,便不能很好的閱讀這一章。

對接口的優劣評價有5項指標,不過歸結只是3個詞而已:簡單,直觀,腳本化。
腳本化是UNIX文化中最重要的東西了吧,在整本書中一直可以看到相關的概念,這種組件的表達方式比起鏈接庫之類的具有更大的獨立性,即使出錯也不會輕易的crash主進程。

不說廢話了。下面簡單列舉并評述一下這一章所描述的接口模式。

1,過濾器模式。從stdin接受數據,轉換成另一種格式后輸出到stdout。需要注意的是,這里是指接受數據,而非命令。該模式具有“單向流”的特點,完全是為腳本化而存在的。
我近段時間曾使用過幾次這種模式,不過不是為了腳本化,而僅僅是為了轉換格式。我所參與的project中,有些看起來很重復的代碼需要重構,比較符合自動化的條件,于是書寫了過濾器,協助重構工作。
實際的經驗中要考慮的是,過濾器的過濾粒度問題,也就是吸收多大一捆數據后,才執行一次格式轉換(可以稱為batch)。根據實際問題的條件,batch的大小有可能是一行,也有可能是幾行,也有可能是所有的數據都到達后才能執行,不過這種情形比較少見。
使用過濾器還有些潛規則是:
寬進嚴出,想必第一次看到這4個字的時候都以為是要限制輸出內容的意思,我也是這樣。不過實際上并不是指內容,而是指格式。能最大程度容忍格式不太規范的輸入,而自身對輸出格式要良好定義,并按這種格式輸出,以便方便下一個程序解析使用。
過濾時,不要丟棄不需要的信息。這個信息是指從stdin讀取的數據。我覺得,這個不能丟棄的信息的粒度是以batch為單位的。某個batch沒有過濾處理,就直接發送到stdout;如果只是batch中的某一行數據沒有過濾處理,實際上整個batch已經利用過了,而還要把那行數據保留輸出,只會引起下游程序的困惑。
過濾時,決不增加無用數據。沉默的法則,待會說。

2,接下來一口氣說3個模式,是因為這些模式或多或少是過濾器的近親,缺胳膊少腿的,又沒有自己的特色,就能有自己的一個模式名,什么世道啊。
cantrip,沒輸入沒輸出,只能通過啟動命令行指定運行;
源模式,沒輸入,但有輸出;
接收器模式,有輸入,但沒輸出;
看完以上,你覺得無聊吧,這3個東西也能有自己的名字···3者有腳本化能力。

3,編譯器模式···在啟動命令行中指定輸入數據文件和輸出數據文件,沒有stdin和stdout。編譯器模式和過濾器模式幾乎做同樣的工作,但是為什么編譯器模式不使用標準輸入輸出呢?UNIX沒有把標準輸入輸出重定向到文件的能力嗎?事實上,在windows下,把過濾器模式變成編譯器的樣子,大概只需要重定向一下,例如:filter.exe? <? input.txt? > output.txt。

4,ed模式。第一次看到ed模式,簡直毫不理解為什么過濾器模式要跑到這來換一個名字繼續騙人。回到剛才聊過濾器模式提到要注意的地方,沒錯了,兩者雖然很像,但有兩個區別:
ed模式接受的是命令,而不是數據。每行一個命令,回車后會執行該命令所代表的功能,同時可能會變遷程序的狀態。
ed模式需要維護會話狀態。過濾器一次性的接受輸入數據,一次性的處理,一次性的輸出數據,在會話尺度上可以說是瞬間的。但是ed模式一次接受一條命令,執行后輸出執行結果,同時程序狀態可能會遷移。
ed模式也可以腳本化的,只是調用程序很可能要確認使用該模式程序的狀態,并且腳本中的命令也要遵循這種狀態才可以。
不過話說回來,ed模式是我們windows用戶學習編程最先用到的程序了。回憶一下曾經寫過的東西,都是輸入回車,然后得到某種執行。呵。

5,Roguelike模式。字符陣列GUI(如果這也可以稱為GUI的話),通過單鍵出發(像游戲手柄一樣),廢棄。

6,接口和引擎分離模式。引擎是指應用程序專用定義域的數據結構和邏輯,比喻為工作者進程也許會更貼切大家;接口負責接受用戶命令,并顯示結果,GUI的或者CLI的。
C/S模式是大家最熟悉的接口和引擎分離模式了。不過本章對此的劃分可是比較細致,我看區卻只是引擎部分的接口模式不同而已,接口部分還是一樣的。以下模式名稱都約定前者為接口,后者為引擎。
配置者/執行者模式。白話的說就是配置者負責配置執行者的執行行為,引擎一般使用類似于cantrip這種無需接口關心其輸出的模式,并且需要接口主動調用。
假脫機/守護進程組合。脫機程序和守護者進程有一個約定的地方,脫機程序就是往那個地方扔東西,而守護者進程就是只打掃那個地方的東西。甚至可以說,接口和引擎完全不需要認識對方,也就不必關心對方的狀態,反正把東西扔那里就沒錯了。
驅動/引擎組合;C/S組合。把兩個合起來說,因為我覺得他們是一樣的。同時由于大家對于C/S的熟悉程度,也無需多說。重要的問題就在設計引擎所接受的命令和返回的狀態的語法上,這可以稱為應用協議或者微型語言。接口需要向引擎發送命令,并獲得引擎的狀態,以便返回給用戶。
綜上所述,接口/引擎分離模式,接口只需要關心協議,而協議指定的工作怎么完成,就無所謂了。

7,CLI服務器模式。不知道這樣一種模式是什么意思···它要說明的只是,服務器使用標準輸入輸出,然后由一個守護程序,把這些輸入輸出連接到套接字上。這,就像是對引擎程序的拆分,服務器使用標準輸入輸出,可以很方便的在缺乏接口/客戶端程序的情況進行本地測試與調試,等接口/客戶端弄好之后,給服務器一個守護進程,守護進程啟動服務器,把服務器的輸入輸出都連接到套接字上,系統就搭建起來了。此外,守護進程一般有做安全門衛的能力。
與其說這是一個模式,倒不如說是解決C/S模式調試的好方法。

8,感謝上帝,終于到多價程序模式了,這種模式在windows下相當的普遍。也就是,程序的應用邏輯被封存在一個API庫中,可以被欲使用其功能的程序編譯鏈接。

9,策略/機制模式。不知道這是不是接口模式,本章沒有多說,但是在別的章節中老說到這個短語。
策略/機制模式,其核心是可配置性,可配置一切一切跟外觀有關的東西,從每一根頭發到每一滴血,從身體到靈魂(局外人:“那是解放者之契約”。偶:“實現汝的愿望”)。
無論是X,還是CEGUI,或者windows,其界面都可以配置。機制是工作的核心邏輯,而策略是一個具體的配置。
說CEGUI,有XXXLook這樣的東西,不同的xxxLook,所看到的是不一樣的東西,但是代碼本身并沒有變。
又如Windows,各種主題,Mac的,番茄花園的,都是一些指定了配置的文本行主題文件,而Windows下的顯示機制,并不需要改變。

10,寫太多了,累了。
posted on 2006-08-21 15:44 LOGOS 閱讀(1285) 評論(0)  編輯 收藏 引用 所屬分類: 《UNIX編程藝術》讀書筆記
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲美女中文字幕| 久久人91精品久久久久久不卡| 一本一本久久| 亚洲精品久久久久| 夜夜精品视频| 亚洲免费婷婷| 欧美一区精品| 久久在线免费观看| 免费看亚洲片| 亚洲精品一区二区三区婷婷月| 亚洲欧洲日韩综合二区| 欧美激情小视频| 91久久视频| 夜夜精品视频| 欧美一区二区三区视频免费播放| 久久久久综合一区二区三区| 毛片基地黄久久久久久天堂| 欧美激情中文不卡| 国产精品视频不卡| 樱花yy私人影院亚洲| 日韩一区二区免费高清| 午夜国产欧美理论在线播放| 欧美aaa级| 中文在线资源观看网站视频免费不卡| 欧美一区二区日韩一区二区| 欧美成人精品| 国产精品视频福利| 亚洲精品123区| 久久精品免费看| 日韩系列欧美系列| 久久天堂av综合合色| 日韩一级网站| 蜜臀a∨国产成人精品| 欧美国产先锋| 国产一区二区三区在线观看视频 | 久久不射中文字幕| 亚洲电影免费观看高清| 9色国产精品| 久久亚洲图片| 国产精品一区二区久久久| 亚洲国产成人久久综合| 午夜精品三级视频福利| 91久久视频| 久久人人爽爽爽人久久久| 国产精品蜜臀在线观看| 亚洲免费观看在线视频| 久久久久久穴| 午夜亚洲性色视频| 国产精品美腿一区在线看| 日韩一级成人av| 欧美国产精品va在线观看| 欧美在线观看网址综合| 国产精品中文字幕在线观看| 在线午夜精品| 91久久久久久| 欧美华人在线视频| 亚洲精品极品| 最新高清无码专区| 欧美裸体一区二区三区| 亚洲精品一区在线观看香蕉| 免费在线日韩av| 久久天天躁夜夜躁狠狠躁2022| 国产一区二区三区电影在线观看| 亚洲伊人一本大道中文字幕| 亚洲人在线视频| 欧美精品一区二区三区四区| 亚洲日本欧美在线| 亚洲国产欧美国产综合一区| 麻豆成人在线播放| 亚洲欧洲一区| 亚洲美女黄网| 国产精品高潮呻吟| 欧美一级在线亚洲天堂| 午夜视频在线观看一区二区三区| 国产日产欧美a一级在线| 久久久久久国产精品mv| 久久婷婷丁香| 99re6这里只有精品| 一本不卡影院| 国产亚洲欧美日韩精品| 免费在线成人av| 欧美凹凸一区二区三区视频| 亚洲精品综合久久中文字幕| 亚洲美女精品成人在线视频| 欧美日韩三区四区| 欧美亚洲一区| 在线观看视频日韩| 亚洲国产精品t66y| 欧美视频中文一区二区三区在线观看| 亚洲欧美日韩精品久久久久| 欧美一区激情| 亚洲毛片视频| 午夜精品久久久久久久| 亚洲国产欧美一区| 亚洲桃花岛网站| 尤物精品国产第一福利三区| 亚洲美女在线观看| 国户精品久久久久久久久久久不卡| 欧美成人免费全部| 国产精品免费看片| 欧美激情中文不卡| 国产在线观看一区| 夜夜嗨av一区二区三区| 永久免费毛片在线播放不卡| 洋洋av久久久久久久一区| 激情文学一区| 亚洲午夜精品一区二区| 亚洲区第一页| 久久精品麻豆| 性欧美videos另类喷潮| 欧美激情中文字幕一区二区| 久久久久久噜噜噜久久久精品| 欧美日韩精品中文字幕| 免费成人黄色片| 国产欧美一区二区精品秋霞影院| 亚洲第一天堂av| 国产欧美精品国产国产专区| 最新日韩av| 在线激情影院一区| 欧美亚洲网站| 欧美一级二区| 欧美午夜无遮挡| 亚洲日本成人女熟在线观看| 伊人精品成人久久综合软件| 亚洲女ⅴideoshd黑人| 中国av一区| 欧美二区在线播放| 欧美国产一区视频在线观看| 狠狠色狠狠色综合| 小黄鸭精品aⅴ导航网站入口| 亚洲一级二级| 欧美日韩视频一区二区| 91久久综合| 一个色综合导航| 欧美人成免费网站| 亚洲国产欧美一区二区三区久久| 亚洲第一精品电影| 久久午夜精品一区二区| 美女视频黄a大片欧美| 狠狠色狠狠色综合人人| 久久久久久久久久久一区| 久久噜噜噜精品国产亚洲综合| 国产在线精品自拍| 久久成人综合视频| 欧美成人一区二免费视频软件| 尤物精品国产第一福利三区| 久久人人97超碰精品888| 欧美成人高清| 亚洲国产欧洲综合997久久| 欧美freesex交免费视频| 亚洲黄一区二区三区| 久久午夜电影网| 亚洲人成毛片在线播放女女| 欧美成在线视频| 99精品国产在热久久婷婷| 亚洲在线黄色| 国产亚洲欧美另类一区二区三区| 欧美与欧洲交xxxx免费观看| 你懂的国产精品永久在线| 亚洲精品久久久久中文字幕欢迎你| 欧美黄色日本| 99re8这里有精品热视频免费 | 亚洲茄子视频| 欧美日韩在线播放三区四区| 亚洲嫩草精品久久| 模特精品裸拍一区| 在线亚洲免费| 国产有码一区二区| 欧美激情va永久在线播放| 亚洲视频一二| 免费影视亚洲| 亚洲在线播放| 狠狠色综合色区| 欧美另类极品videosbest最新版本| 亚洲一区二区三区高清| 欧美77777| 午夜在线观看欧美| 91久久精品日日躁夜夜躁国产| 欧美日韩亚洲一区二区三区| 午夜视频在线观看一区二区| 亚洲高清视频一区| 欧美一区二区三区在线观看视频| 在线观看视频免费一区二区三区| 欧美日韩一区国产| 久久综合九色综合久99| 亚洲一区二区三区涩| 欧美福利影院| 久久精品国产清自在天天线 | 欧美日韩亚洲一区| 久久精品三级| 亚洲一级片在线看| 亚洲精品国产视频| 美女亚洲精品| 欧美一区二区三区在线| 在线一区观看| 亚洲精品视频一区二区三区| 国产综合久久久久影院| 国产精品视频yy9299一区| 欧美伦理91i| 欧美本精品男人aⅴ天堂|