并发性与并行性的差别【转】

并行性包含同时性和并发性,前者是指两个或多个事件在同一时刻发生,后者是指两个或多个事件在同一时间段内发生。

  计算机操作系统中把并行性和并发性明显区分开,主要是从微观的角度来说的,具体是指进程的并行性(多处理机的情况下,多个进程同时运行)和并发性(单处理机的情况下,多个进程在同一时间间隔运行的)。

所谓并行性(parallelism)是指在同一时刻或是同一时间间隔内完成两种或两种以上性质相同或不相同的工作。只要时间上互相重叠,就存在并行性。严格来讲,把两个或多个事件在同一时刻发生的并行性叫做同时性(simultaneity);而把两个或多个事件在同一时间间隔内发生的并行性叫做并发性(concurrency)位并行加法为例,由于存在着进位信号的传播延迟时间,全部位加法结果并不是在同一时刻获得的,因此并不存在同时性,而只存在并发性的关系。如果有个存储器模块能同时进行读出信息,则属于同时性。

      

       并行的事件或活动一定是并发的,反之并发的事件或者活动未必就是并行的。并行性事并发性的一个特例。

      

       并发性描述的其实是两个事件在一个时间间隔内发生,但未必会同时进行,也有可能会在某一时间重叠区域中同时进行,这就要看这个时间间隔如何定义了。而并行性体现在同一时刻上不同的事件都正在进行着。比如,两个人,一部电话,时间8:00-8:10这个时间段内,两个人都想打电话体现了前面所说的并发性,但是只有一部电话,谁先来谁用,就不可能出现两个人同时打电话的情况。

       所以,同一时间间隔内发生,但不同时进行的情况在内核中会出现很多,通常在资源有限的情况下会体现得更明显。

你可能感兴趣的:(我的linux学习之路)