这一篇再继续就线程进行一些更深层次的研究
线程所需的资源
- 进程中各个线程共享代码、数据和文件等资源,记录线程运行状态的空间(TCB)每个线程单独有一个
- 每个进程都需要它自己私有的线程控制块(TCB)列表,用来跟踪记录它的各个线程的状态信息(PC、栈指针、寄存器)
线程的实现
- 用户线程,在用户空间实现,OS看不到用户线程,TCB由用户线程库管理和维护,POSIX Pthreads、Mach C-threads、Solaris threads等OS线程是通过用户线程的方式实现的
- 内核线程,在内核中实现,OS可以看到,TCB由OS管理、调度和维护,Windows、Solaris、Linux等OS线程是通过内核线程实现的
- 轻量级进程,在内核中实现,支持用户线程,Solaris(Lightweight Process)
用户线程
- 在用户空间实现的线程机制,它不依赖于OS的内核,由一组用户级的线程库函数来完成线程的管理,包括线程的创建、终止、同步和调度等
- 由于用户线程的维护由相应进程来完成(通过线程库函数),不需要OS内核了解用户线程的存在,可用于不支持线程技术的多进程OS
- 用户线程的切换也是由线程库函数来完成,无需用户态/核心态切换,所以速度特别快
- 允许每个进程拥有自定义的线程调度算法
用户线程的缺点
- 一个线程发起系统调用而阻塞,则整个进程在等待
- 当一个线程开始运行后,除非它主动地交出CPU使用权,否则它所在的进程当中的其他线程将无法运行
- 由于时间片分配给进程,故与其它进程比,在多线程执行时,每个线程得到的时间片较少,执行会比较慢
内核线程
- 在OS的内核当中实现的一种线程机制,由OS的内核来完成线程的创建、终止和管理
- 在支持内核线程的OS中,由内核来维护进程和线程的上下文信息(PCB和TCB)
- 线程的创建、终止和切换都是通过系统调用/内核函数的方式来进行,由内核来完成,因此OS开销比较大
- 在一个进程当中,如果某个内核线程发起系统调用而被阻塞,并不会影响其他内核线程的执行
- 时间片分配给线程,多线程的进程获得更多CPU时间
轻量级进程
- 它是内核支持的用户线程,一个进程可有一个或多个轻量级进程,每个轻量级进程由一个单独的内核线程来支持(Solaris和Linux)
如有侵权,请联系删除,如有错误,欢迎大家指正,谢谢