




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
Chapter4(Threads)–StudyThreadAthreadisabasicunitofCPUIthasathreadID,programcounter,aregistersetandaItshareswithotherthreadsbelongingtothesameprocess,itscodesection,datasection,andotherOSresources,suchasopenfilesandBenefitsofmultithreadedResponsiveness–Lengthyoperations,suchasadifficultcomputationoranotherIOeventsuchasnetworkcommunicationcanbedoneinparallelwithblockingIOorotherlengthyoperations.能處理復(fù)雜冗長(zhǎng)的與計(jì)ResourcesharingThreadssharedataandcodespacethuseachthreadcanrapidlycommunicateandreduceduplicationthatwouldhaveoccurredwithmultipleprocesses.數(shù)據(jù),減少Efficiency–Inadditiontoreducedresourceusage,contextswitchingandthreadcreationcanbedonemoreefficientlythantheequivalentlogicwithprocesses,becausefarlessdatamustbeswitchedout.Scalability–Whileasingleprocessmayonlyrunonaprocessoramultithreadedapplicationcanmoreeasilytakeadvantageofmultiprocessorandmulticoresystemswitheachthreadrunningonadifferentprocessor/core.擴(kuò)展性高UserandKernelthreadsandtheirUserthreads:applicationmanagesthreadmanagementkernelisnotawareoftheexistenceofthreadsKernelthreads:threadmanagementdonebytheKernel.Thereisnothreadmanagementcodeintheapplicationarea.Multicoresystems–dataparallelism&taskDataparallelism–distributessubsetsofthesamedataacrossmultiplecores,sameoperationoneachTaskparallelism–distributingthreadsacrosscores,eachthreadperforminguniqueoperationMultithreadingmodels(many-to-one,one-to-one,many-to-One-to-OneEachuser-levelthreadmapstokernelBenefits:MoreconcurrencythatMany-to-Drawback:Numberofthreadsperprocesssometimesrestrictedduetooverheadofcreatingakernelthreadassociatedwitheachnewuser-threadcreated.Many-to-OneManyuser-levelthreadsmappedtosinglekernelBenefits:LesscostbysharingonekernelamongmultipleDrawbacks:Onethreadblockingcausesblockingofalltheotherthreads.ManytoManyAllowsmanyuserlevelthreadstobemappedmanykernelThreadThreadlibraryprovidesprogrammerwithAPIforcreatingandmanagingImplicit產(chǎn)生的原因:Growinginpopularityasnumbersofthreadsincrease,programcorrectnessmoredifficultwithexplicitthreads。實(shí)現(xiàn)方法:Creationandmanagementofthreadsdonebycompilersandrun-timelibrariesratherthanprogrammers。ThreadDefinition:Sincewhenevertheserverreceivesarequest,ithastocreateaseparatethreadtoservicetherequestandwhentheserviceiscompletedthethreadgetsdiscarded,thiswillresultinoverhead.Theideabehindthreadpooliscreateanumberofthreadsatprocessstartupandcethemintoapool,andwaitforworktobeassignedtothem.Threadpoolisusuallyaqueue.Whenevertheserverreceivesarequest,ifathreadisavailableinthepool,willreceivetherequest,processesitandonceit’scompletedthethreadwillreturntothethreadpoolandwaitsforthenextrequesttobeassignedtoit.SettingthenumberofthreadsinapooldependsonfactorssuchasthenumberofCPUsinthesystem,thenumberofphysicalmemory,andtheexpectednumberofconcurrent requests.SomethreadpoolsadjustthenumberofthreadsinthepoolaccordingtotheusagepatternUsuallyslightlyfastertoservicearequestwithanexistingthreadthancreateanewthreadAllowsthenumberofthreadsintheapplication(s)tobeboundtothesizeofthepoolSeparatingtasktobeperformedfrommechanicsofcreatingtaskallowsdifferentstrategiesforrunningtaskThreadcancellation(Asynchronous&Deferredcancellation,Cancellationspoint)Asynchronouscancellation–whereonethreadimmediayterminatesthetargetthread.Problemsassociatedwithasynchronouscancellationscouldinclude,operatingsystemnotbeingreclaimbacksomeoftheresourcesallocatedtocancelledthreads,andtherefore,asystem-wideresourcemaynotbed.Also,athreadmaygetcancelledinthemidstofupdatingdataitissharingwithotherthreads.Deferredcancellation–wherethetargetthreadperiodicallycheckswhetheritshouldterminate,allowingittoterminateitselfinanorderlymanner.Withdeferredcancellation,cancellationonlyoccurswhenthreadreachescancellationpoint.Thatistosay,onethreadindicatesthatatargetthreadisgoingtobecancelled,butcancellationoccursonlyafterthetargetthreadhascheckedaflagtodetermineifitshouldbecancelledornot.Thisallowsthethreadtobecancelledatasafepoint,deferredtoascancellationpoint.評(píng):根據(jù)我十萬(wàn)行的代碼開發(fā)經(jīng)驗(yàn),Deferredcancellation確實(shí)threadcancellation還是要依據(jù)thread的模式滴。SignalhandlingSignalsareusedtonotifyaprocessthataparticulareventhasoccurred.Therearetwotypesofsignals:Synchronoussignals(ex:illegalmemoryaccessanddivisionbyAsynchronoussignals(ex;terminatingaprocesswhenyou<control><C>orhavingatimeAsignalmaybehandledbyoneoftwopossiblehandlers:AdefaultsignalhandlerAuser-definedsignalEverysignalhasadefaultsignalhandlerthatthekernelrunswhenhandlingthatsignal.Thisdefaultactioncanbeoverriddenbyauser-definedsignalhandlerthatiscalledtohandlethesignal.Insingle-threadedprograms,signalsaredeliveredtotheprocess.Inmultithreadedprograms,therearedifferentoptionsforsignalDeliverthesignaltothethreadtowhichthesignalDeliverthesignaltoeverythreadintheDeliverthesignaltocertainthreadintheAssignaspecificthreadtoreceiveallsignalsfortheThemethodfordeliveringasignaldependsonthetypeofsignalsEx:synchronoussignalsneedtobedeliveredtothethreadcausingthesignalandnottootherthreadsintheprocess.Thread-LocalThreadsbelongingtothesameprocesssharethedataoftheprocess.However,insomecases,eachthreadmightneeditsowncopyofcertaindata.Thisisusefulincaseswhenwedon’thavecontroloverthethread評(píng):TLSthreadsdataTLS,讓threadsprivatedata.DifferentfromlocalLocalvariablesvisibleonlyduringsinglefunctioninvocation.ButTLSvisibleacrossfunctioninvocationsSchedulerBoth,Many-to-ManyandTwo-levelmodelsrequirecommunicationtomaintaintheappropriatenumberofkernelthreadsallocatedtotheapplication.Oneschemeforcommunicationbetweentheuser-threadlibraryandthekernelisknownasscheduleractivation。Light-weightAlightweightprocess(LWP),whichisanintermediatedatastructurecedbetweenuserandkernelthreads,canbeusedasavirtualonwhichaprocesscanscheduleauserthreadto
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 信息技術(shù)在零售行業(yè)的應(yīng)用能力培訓(xùn)
- 建筑行業(yè)的徒弟職業(yè)規(guī)劃計(jì)劃
- 特殊場(chǎng)所消防維保工作流程規(guī)范
- 如何在中考中表達(dá)自信:2025年作文《肯定自己》分析
- 雙減政策對(duì)課外培訓(xùn)市場(chǎng)的沖擊心得體會(huì)
- 機(jī)場(chǎng)地勤作業(yè)安全管理措施
- 小學(xué)英語(yǔ)學(xué)習(xí)動(dòng)機(jī)激勵(lì)計(jì)劃
- 2024-2025七年級(jí)下學(xué)期班級(jí)文化建設(shè)計(jì)劃
- 遠(yuǎn)程會(huì)診室數(shù)據(jù)管理流程優(yōu)化策略
- 航空航天領(lǐng)域安全風(fēng)險(xiǎn)管理與防范措施
- ISO28000:2022供應(yīng)鏈安全管理體系
- 招標(biāo)代理服務(wù)投標(biāo)技術(shù)方案技術(shù)標(biāo)
- 2024年浪潮入職測(cè)評(píng)題和答案
- 全媒體運(yùn)營(yíng)師-國(guó)家職業(yè)標(biāo)準(zhǔn)(2023年版)
- 建筑施工現(xiàn)場(chǎng)安全警示牌標(biāo)示(標(biāo)志圖片)
- 《吸收與解吸》課件
- 智慧城市產(chǎn)業(yè)發(fā)展
- 建行存款保險(xiǎn)知識(shí)講座
- 《工廠供配電技術(shù)》課件
- 2024年中考英語(yǔ)熱點(diǎn)閱讀練習(xí)9 中秋節(jié)(含解析)
- CT設(shè)備維保服務(wù)售后服務(wù)方案
評(píng)論
0/150
提交評(píng)論