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

隨筆 - 119  文章 - 290  trackbacks - 0

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

常用鏈接

留言簿(12)

隨筆分類

我的博客

搜索

  •  

積分與排名

  • 積分 - 306398
  • 排名 - 84

最新評論

閱讀排行榜

UNIX文化,提倡的是一種簡潔,直觀,低復雜度的文化.
UNIX倡導多進程編程,而不是大家所熟悉的多線程編程.
由于進程有自己獨立的地址空間,因此多進程之間的協(xié)作與交互,通關(guān)操作系統(tǒng)提供的各種IPC方法實現(xiàn).
在討論IPC的那個章節(jié)里,提出了管道,信號,臨時文件,共享內(nèi)存,套接字幾個模型.

我一般寫東西玩的時候,總是喜歡建立控制臺程序,因為輸入輸出庫都比較簡單,并且所見即得.管道/重定向之類,都是建立在標準輸入/輸出的基礎(chǔ)上.這里所描述的管道/重定向,并不是在一個進程中調(diào)用CreatePipe,改變管道方向,然后用CreateProcess建立一個子進程.UNIX所用的方式類似于.bat命令,比如 dir | more,用符號"|"連接兩個進程的管道.事實上,一般能用上管道/重定向的進程,都是一個過濾器,數(shù)據(jù)從標準輸入進來,經(jīng)過加工后從標準輸出跑掉.因此,管道/重定向技術(shù)對于流水線般加工的任務,是一個相當棒的模型.
需要注意的是,使用管道模型的程序,通常數(shù)據(jù)流/協(xié)議(在某個任務下)是單向的.
總體上,在WINDOWS下像UNIX那樣使用管道/重定向機制,通常是用C/C++寫許多獨立但是可以連接的程序,然后用bat的方式,將其按所需任務組合.如果希望在程序中可以像bat那樣啟動其他進程,只要用簡單的system(command)函數(shù)就好了,WINAPI通常都是復雜而累贅的.

UNIX下的信號,是對進程發(fā)出的,由進程的相應回調(diào)函數(shù)處理,程序可以重載自己的實現(xiàn).這和WINDOWS下的消息比較相像,只是WM通常都需要窗口.由于信號/消息能傳遞的數(shù)據(jù)都比較薄弱簡單,所以這通常作為一種輔助機制,和其他IPC模型共同協(xié)作.

臨時文件,是一種能解決雙向溝通的模型,但是并不利于做復雜的事情,最好的用途是在簡單,需要雙方溝通,大數(shù)據(jù)量的情形下.使用方法大概描述為,A進程調(diào)用執(zhí)行某個任務的B進程,B進程將執(zhí)行結(jié)果寫入A進程指定的文件,A進程使用該文件.
一個隱患是,一旦破壞程序知道臨時文件的位置,就可能破壞該文件.
其實臨時文件和接下來所說的共享內(nèi)存在功能上并無太大區(qū)別.唯一不同的是,臨時文件所使用的API,都是很容易跨平臺的.

共享內(nèi)存,是一個和操作系統(tǒng)密切相關(guān)的IPC模型,作為生產(chǎn)者/消費者系統(tǒng)的一個性能優(yōu)化的解決方案,其最大的優(yōu)勢便是對大型數(shù)據(jù)傳遞所提供的效率.但是,預防競爭/死鎖是必須考慮的問題.我覺得,由于共享內(nèi)存的API通常是專有的,不易于跨平臺,所以使用共享內(nèi)存的條件應該比較嚴格,必須要在性能需求高和一次數(shù)據(jù)交換量巨大的情況下才可以考慮,而且,臨時文件是一個可以考慮的替代模型.

套接字,是一個直觀并且在眾多操作系統(tǒng)中廣泛使用的模型,不用說也知道是一個好東西了.

在《UNIX編程藝術(shù)》中,認為大多數(shù)的IPC方法都是可以相互替代的,因此最重要的是選擇一個盡可能使系統(tǒng)簡單的模型.此外,特別說多線程不該是最先考慮到的方法,而是最后一個.
多線程將子任務糅合在一個程序中,而不是分開,增加了全局復雜度.此外,多線程帶來的2個不可避免的BUG:時序問題,還有競爭/死鎖的問題.縱然全局變量提升了任務之間的溝通效率,但是通常這種效率都被昂貴的鎖定/解鎖所抵消了.
特別是,使用多線程的程序所依賴的庫,并非都是線程安全的,其中一旦產(chǎn)生的問題,會使得你麻煩重重,特別是,多線程的程序調(diào)試......由于時序問題,你自己想想都知道了.
因此,非要使用多線程,理想(意味著不可能存在)的約束是,線程盡量不使用全局變量;每個變量只被一個線程使用;被線程使用的變量不再被主進程使用;線程中不使用static變量.....這種約束,根本沒有辦法實現(xiàn)嘛.

posted on 2006-08-13 11:06 LOGOS 閱讀(2334) 評論(8)  編輯 收藏 引用 所屬分類: 《UNIX編程藝術(shù)》讀書筆記

FeedBack:
# re: IPC,讀《Unix編程藝術(shù)》某章感 2006-08-14 17:19 yifeng
首先謝謝你的文章。
你說的這一段書,我也有看,但存在疑問。

線程A發(fā)生內(nèi)存溢出,可能會波及到線程B。
或因為線程A的錯誤,使程序崩潰,連帶波及線程B。
這些意外狀況,是我唯一想到的差別。
(還有你說的開發(fā)過程中難調(diào)試的問題)

除此,我沒想到實際差別。
任務邏輯解耦得好,和使用進程或線程沒有關(guān)系
如果一個進程的運行完全不需要和另一個進程通信,
那么設(shè)計出來的線程任務也一樣不需要通訊,反之亦然。

一般,使用對象,能把線程任務封裝得很好,輸入和輸出清晰。
兩個進程使用共享內(nèi)存,也需要保護,其情況和線程間共享數(shù)據(jù)結(jié)構(gòu)無異。

所以我不能理解把“時序問題、競爭/死鎖問題”歸為線程帶來問題。

為此我想到了一種解釋,就是進程模型喜歡使用耦合度更低的通訊模式,例如Socket,
而用線程的人則一般不愿意這樣做,而是直接回調(diào),共享數(shù)據(jù)結(jié)構(gòu)。
不是因為線程模型比進程模型會帶來復雜,
而是因為選用了不同的通訊手段,導致復雜性不同。  回復  更多評論
  
# re: IPC,讀《Unix編程藝術(shù)》某章感 2006-08-14 19:35 LOGOS
呵呵.怎么說呢.
討論IPC,就說明討論的是需要通訊的任務(進程/線程).
線程與進程的本質(zhì)區(qū)別,應該是地址空間問題.進程是獨立的,線程是共享的.
UNIX的元老們最害怕的應該就是沒有隱私吧.
線程的通訊方式通常是共享數(shù)據(jù)結(jié)構(gòu)(全局變量),全局變量是單份的,線程們要使用的話,必須競爭.如果線程過多,資源的分布過分復雜,也許會有意想不到的死鎖問題.通常死鎖....誰能預見呢?
至于時序問題,其實在大學有認真學習過"操作系統(tǒng)",都知道怎么完美的控制各個任務的執(zhí)行時序的.
的確,不能說“時序問題、競爭/死鎖問題”歸為線程帶來問題,不過這兩個問題領(lǐng)域,似乎是在線程編程的時候才顯得尤其突出的.

使用對象的確能把線程封裝得很好,不過這種很好,仔細想想,是對于不需要通訊的線程很好吧.只要用全局變量進行通訊,還是會繞回原來的點上.

另外,將任務做成進程而不是線程還基于這樣一個理由,重用.
雖然說線程的代碼包裝得好,可以像一個類庫一樣重用.但是一個進程的重用,是在編譯成一個執(zhí)行文件之后,用批處理調(diào)用的重用.
你覺得是一個類(包含不少接口,并且有調(diào)用順序/環(huán)境之類的約束,要命的是好像它還是線程)重用得順手,還是像"SomeTast.exe -SomeParam"這樣在主程序中執(zhí)行bat命令舒坦呢?
因人而異吧.

并沒有反對線程的意思.只是想說,能用簡單的先用簡單的吧.下班越早越好,是吧.  回復  更多評論
  
# re: IPC,讀《Unix編程藝術(shù)》某章感 2006-08-15 11:37 yifeng
啊,別誤會,沒有說誰反對線程或進程的意思。
只是單純的探討。

我認為只要有并發(fā)和競爭就會有死鎖的可能,進程也不例外。
我最大的疑問是,我假想不出具體的情形,能說明線程遭遇的問題比進程更突出。
而我只能理解為"他們使用了不同的通訊手段"

我的工作語言是C++,線程共享的一般不會是全局對象,而是局部的。
在創(chuàng)建線程任務時,讓他們持有共享對象的句柄。
目前為止,我未發(fā)現(xiàn)在控制他們的生命周期上有困難。
所以也沒有發(fā)現(xiàn)使用全局對象的必要。

但,一般我會在資源上使用大粒度鎖,假如我沒有發(fā)現(xiàn)功能或性能上有細化的必要。
這也就盡量避免了拿到了叉子等刀子的情況。
線程過多,資源的分布過分復雜的情況,的確很難控制。
但也使我懷疑這種情況下使用進程模型是否合適。
  回復  更多評論
  
# re: IPC,讀《Unix編程藝術(shù)》某章感 2006-08-15 12:43 LOGOS[offline]
和你討論線程,我有點心虛.因為我對線程僅限于概念性認識而已.
你說"在創(chuàng)建線程任務時,讓他們持有共享對象的句柄。", 這個"共享對象句柄"不是全局的嗎?我猜你的意思可能是他們的生命周期處于一個局部過程內(nèi),但是會比持有他們線程要長,也就是主函數(shù)內(nèi).那么我想拓展我所說的全局的意思,廣義上,凡是被多個線程競爭的變量,其意義都和全局變量無異.
事實上,我所在意的也就是線程競爭變量的問題.因為那些變量用于通訊.

對于資源分布復雜,我覺得這對進程沒有多大影響.因為在討論線程的時候,所謂的資源只是簡單的指那些被競爭的變量.對于進程而言,通信的數(shù)據(jù)都是以副本存在的.可能你的意思是像文件之類的資源,這種資源屬于硬件資源,由于本身的有限性,無論如何也都要競爭啦.

應該說,線程一樣可以很好的編程,很好的工作.但是UNIX文化中極力提倡程序是可以腳本化的(也就是批處理文件那樣子),以便于復用.這一點線程好像沒什么辦法可以做到哦,再加上不統(tǒng)一的API問題,所以也就不怎么被推薦.
此外,考慮到本書作者是一個憤青(譯者說),徹底的反GUI,反二進制的家伙,偏見也就不足為其了.  回復  更多評論
  
# re: IPC,讀《Unix編程藝術(shù)》某章感 2006-08-15 12:46 LOGOS[offline]
PS:進程在管道模型下,腳本包裝模型下,可以認為是順序工作的.在套接字下是并發(fā)工作. 同時獨立的地址空間.
而線程一開始就是并發(fā),而且共生共用的.  回復  更多評論
  
# re: IPC,讀《Unix編程藝術(shù)》某章感 2006-08-16 10:20 lingate
所謂的"徹底的反GUI,反二進制的家伙",實在言過其實了,因為作者一再強調(diào)界面和策略相關(guān),而且在例子中作者推薦了一款業(yè)余人員特別喜歡的發(fā)送郵件的軟件,作者就認為界面設(shè)計很好,即照顧了普通用戶的需要又很好的顯示程序的狀態(tài)。在后面的大量篇幅中作者一直在說明程序編寫需要簡單性與透明性,也是一個標準的以人為本的思路,譯者的一家之言,請不要因此用帶色眼鏡看他。  回復  更多評論
  
# re: IPC,????Unix???????????¸? 2007-08-10 18:36 xmlscript@hotmail.com
????????д???webserver???????????windows???????????????unix?汾????????????ö????????????б??unix??????ö?????
?????unix????????????????????????win32???????unix?µ????????webserver????δ??????????????  回復  更多評論
  
# re: IPC,讀《Unix編程藝術(shù)》某章感 2007-08-10 18:37 xmlscript@hotmail.com
我最近在編寫一個webserver,為方便,先在windows里構(gòu)件,最終目的是unix版本。很自然我要使用多線程,但你文中表示unix下最好用多進程?
由于對unix的無知和向往,使我暫停了手頭win32的開發(fā)。unix下的成熟的商業(yè)webserver是如何處理這一關(guān)系的呢?  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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片| 黑人巨大精品欧美黑白配亚洲| 欧美日韩在线不卡| 国产精品99免费看| 国产精品成人v| 国产精品影院在线观看| 欧美成人xxx| 欧美黄色精品| 亚洲性线免费观看视频成熟| 亚洲美女av电影| 一本久久综合亚洲鲁鲁| 欧美亚洲色图校园春色| 美女脱光内衣内裤视频久久网站| 久久免费视频在线| 国产精品免费网站| 亚洲成色777777女色窝| 亚洲视频免费观看| 欧美sm极限捆绑bd| 亚洲无限乱码一二三四麻| 久久av一区| 国产欧美日韩视频| 在线一区二区三区四区| 欧美 日韩 国产在线| 亚洲全部视频| 欧美诱惑福利视频| 欧美日韩视频在线第一区| 在线播放中文一区| 久久精品99国产精品日本| 一区二区三区久久久| 亚洲欧美色一区| 国产精品高清在线观看| 一本色道久久综合亚洲精品小说| 久久精品人人做人人爽电影蜜月| 亚洲国产精品久久久久婷婷884 | 99在线热播精品免费| 久久精品国产成人| 欧美在线高清| 亚洲高清免费视频| 亚洲欧洲精品一区| 欧美激情视频网站| 欧美巨乳在线观看| 午夜精品短视频| 欧美中文在线字幕| 夜夜嗨av一区二区三区免费区| 亚洲精品少妇30p| 国产精品麻豆欧美日韩ww| 欧美制服第一页| 欧美/亚洲一区| 亚洲尤物视频网| 久久久91精品国产一区二区三区| 激情欧美一区| 亚洲人成7777| 激情综合激情| 在线视频亚洲欧美| 在线视频成人| 午夜一区二区三视频在线观看| 亚洲电影自拍| 久久精品水蜜桃av综合天堂| 99国产精品一区| 久久手机免费观看| 久久精品国产久精国产爱| 欧美日韩国产综合视频在线| 欧美一区二区性| 欧美日韩在线直播| 欧美激情视频免费观看| 激情综合网址| 欧美一区二区三区在线观看视频 | 欧美成人视屏| 国产日韩欧美精品综合| 亚洲视频视频在线| 亚洲欧美久久| 日韩视频一区二区在线观看| 欧美精品在线观看播放| 欧美欧美天天天天操| 久久资源av| 韩国久久久久| 久久精品中文| 亚洲电影下载| 亚洲精品日韩久久| 欧美激情欧美狂野欧美精品| 欧美成人一区二区三区| 激情久久久久久久| 久久资源在线| 亚洲国产成人在线播放| 亚洲国产乱码最新视频| 久久在线播放| 在线视频日韩精品| 久久露脸国产精品| 亚洲国产综合在线看不卡| 欧美小视频在线| 久久精品国产欧美亚洲人人爽| 久久免费少妇高潮久久精品99| 精品盗摄一区二区三区| 欧美日韩国产综合视频在线观看| 中国日韩欧美久久久久久久久| 久久福利毛片| 亚洲第一中文字幕| 国产精品白丝黑袜喷水久久久| 欧美综合77777色婷婷| 亚洲老司机av| 亚洲国产精品久久久久婷婷884| 亚洲在线不卡| 一区二区免费看| 亚洲精品一二三区| 亚洲精品1区2区| 伊人久久噜噜噜躁狠狠躁| 亚洲丰满在线| 乱中年女人伦av一区二区| 午夜精品成人在线视频| 99热在这里有精品免费| 在线播放豆国产99亚洲| 国产精品外国| 国产日韩欧美一区二区三区在线观看 | 欧美日韩dvd在线观看| 久久一区亚洲| 你懂的视频一区二区| 美女日韩欧美| 欧美日韩国产一区| 国产精品天天看| 国产精品日韩专区| 激情六月综合| 日韩视频亚洲视频| 亚洲欧美激情视频| 久久久久久久97| 欧美凹凸一区二区三区视频| 欧美xart系列高清| 亚洲桃花岛网站| 久久天堂av综合合色| 欧美日韩综合另类| 国内精品嫩模av私拍在线观看| 18成人免费观看视频| 亚洲素人在线| 欧美高清一区二区| 亚洲欧美中文日韩在线| 免费亚洲电影在线| 黑人巨大精品欧美一区二区小视频| 亚洲精品免费一区二区三区| 欧美一区二区三区久久精品茉莉花| 久久视频在线看| 亚洲午夜精品福利| 欧美日韩国产精品 | 日韩午夜在线观看视频| 午夜激情综合网| 欧美色欧美亚洲高清在线视频| 在线观看久久av| 老司机67194精品线观看| 午夜精品久久久久久久99水蜜桃| 免费看亚洲片| 亚洲美女在线一区| 亚洲精品国产精品国自产观看| 欧美亚洲免费| 一区在线播放| 亚洲第一黄网| 欧美日韩在线三区| 亚洲综合色丁香婷婷六月图片| 亚洲欧洲久久| 国产精品视频一| 久久久噜噜噜久噜久久| 久久人人爽国产| 99re热这里只有精品视频| 欧美激情精品久久久久久久变态 | 亚洲在线一区二区| 国产主播一区二区| 欧美电影免费观看高清| 欧美欧美天天天天操| 午夜免费久久久久| 久久久久久久一区二区三区| 影音先锋日韩资源| 亚洲视频免费看| 亚洲黄色天堂| 久久精品免费观看| 欧美黄色一区二区| 亚洲精选一区二区| 免费看的黄色欧美网站| 蜜臀91精品一区二区三区| 韩国av一区二区三区四区| 久久丁香综合五月国产三级网站| 欧美自拍偷拍| 在线免费观看日韩欧美| 欧美18av| 亚洲欧美日韩国产中文在线| 久久国产黑丝| 亚洲精品乱码久久久久| 国产精品成人国产乱一区| 亚洲欧美一区二区激情| 国产视频在线观看一区二区三区| 91久久久久| 午夜精品视频在线| 在线免费观看视频一区| 亚洲高清视频在线| av成人黄色| 欧美黄色影院| 日韩视频亚洲视频| 亚洲女同精品视频| 国产精品免费一区二区三区观看 | 精品91免费|