预览加载中,请您耐心等待几秒...
1/10
2/10
3/10
4/10
5/10
6/10
7/10
8/10
9/10
10/10

亲,该文档总共21页,到这已经超出免费预览范围,如果喜欢就直接下载吧~

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

操作系统原理与设计 第4章Threads2(线程2) 陈香兰 中国科学技术大学计算机学院 December20,2009 ...... 提纲 OSExamplesforThread ThreadScheduling OSExamplesforThreadScheduling 小结和作业 ...... Outline OSExamplesforThread ThreadScheduling OSExamplesforThreadScheduling 小结和作业 ...... WindowsXPThreadsI IAnWindowsXPapplicationrunsasaseperateprocess,and eachprocessmaycontainoneormorethreads. IImplementstheone-to-onemapping Ieachuser-levelthreadmapstoanassotiatedkernelthread Ianythreadbelongingtoaprocesscanaccesstheaddressspace oftheprocess IEachthreadcontains IAthreadid IRegisterset ISeparateuserandkernelstacks IPrivatedatastoragearea ITheregisterset,stacks,andprivatestorageareaareknownas thecontextofthethreads ...... WindowsXPThreadsII ITheprimarydatastructuresofathreadinclude: IETHREAD(executivethreadblock) IKTHREAD(kernelthreadblock) ITEB(threadenvironmentblock) ...... WindowsXPThreadsIII ...... LinuxThreads ILinuxreferstothemastasksratherthanthreads IThreadcreationisdonethroughclone()systemcall Iclone()allowsachildtasktosharetheaddressspaceof theparenttask(process) Iclone()VS.fork() ...... JavaThreads IJava在语言级提供线程创建和管理支持功能 IJavathreadsaremanagedbytheJVM,notuser-levellibraryor kernel IJavathreadsmaybecreatedby: IExtendingThreadclass IImplementingtheRunnableinterfaceJava ...... ThreadStates ...... Outline OSExamplesforThread ThreadScheduling OSExamplesforThreadScheduling 小结和作业 ...... ThreadScheduling Iuser-levelthread:kernel-levelthread(orLWP) ILocalScheduling–Howthethreadslibrarydecideswhich threadtoputontoanavailableLWP Imany-to-one,many-to-manymodels Iprocess-contentionscope,PCS IGlobalScheduling–Howthekerneldecideswhichkernel threadtorunnext Imany-to-one,many-to-many&one-to-onemodels Isystem-contentionscope,SCS ...... PthreadSchedulingAPII IPOSIXPthreadAPIallowsspecifyingeitherPCSorSCS duringthreadcreation IPTHREADSCOPEPROCESS,many-to-many IPTHREADSCOPESYSTEM,one-to-one IcreateandbindanLWPforeachuser-levelthread Iexample #include<pthread.h> #includ