线程概念

线程是指程序中的一个单一的顺序控制流,它很好地刻划了紧耦合共享主存的多处理机体系结构上的并行处理行为。
  进程作为资源的分配单位和保护单位,为线程提供运行的静态环境,但在处理机上调度的基本单位却是线程。

线程概念

  在传统上,并发多任务的实现采用的是在操作系统(OS)级运行多个进程。由于各个进程拥有自己独立的运行环境,进程间的耦合关系差,并发粒度过于粗糙,并发实现也不太容易。当前,采用多处理机构成超高性能计算机成为主流。为发挥新体系结构的并行效率提出一些新概念和支持并行程序的机制。在这种背景下,针对传统UNIX中进程的概念在支持中微粒度并行程序设计方面的不足,提出了线程概念。如果把进程所占资源与进程中的运行代码相分离,那么在一个地址空间中便可运行多个指令流,由此产生线程概念。这一概念在表达应用问题本身的并行性方面较传统进程有较大优势,尤其在共享主存的多处理机硬件环境上有更好的运行效率。但是,线程尚没有统一的定义,一般说来,所谓线程(或称线索),指程序中的一个单一的顺序控制流。
  图1和图2分别示意了把一个任务按2个并发进程和2个并发线程分解后的情况。比较这两张图中进程与进程之间、线程与线程之间的关系可以看出,进程间的关系比较疏远。各个进程是在自己独有的地址空间内执行,不但寄存器和堆栈是独有的,动态数据堆、静态数据区和程序代码也相互独立。而线程间的关系则要紧密得多,虽然各线程为保持自己的控制流而独有寄存器和堆栈,但由于两线程从属于同一进程,它们共享同一地址空间,所以动态堆、静态数据区及程序代码为各线程共享。进程作为独立的实体,它为线程提供运行的资源并构成静态环境。线程是处理机调度的基本单位。如果说进程概念很好地描述了单机操作系统行为,那么线程概念则很好地描述了多机系统中的并行处理行为,将起到进程在单机操作系统中类似的历史作用。

  

所谓多线程程序设计,指使单个程序中包含并发执行的多个线程。当多线程程序执行时,该程序对应的进程中就有多个控制流在同时运行,即具有并发执行的多个线程。在一个进程中包含并发执行的多个控制流,而不是把多个控制流一一分散在多个进程中,这是多线程程序设计与多进程程序设计截然不同之处。
  正是由于线程与进程之间的这些差别,决定了多线程技术的优越性。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值