Qt C++ 并发,并行,多线程编程系列1 什么是并发

什么是并发,并发往简单来说就是两个或多个独立的任务同时发生,在我们的生活中也是随处可见。如果把每个人都当作一个独立的任务,那每个人可以相互独立的生活,这就是并发。



在计算机的系统里面,并发一般有两种,一种是通过任务切换来实现伪并发,这种实现方式是系统在一秒钟内切换运行多个任务,由于切换时间极短,使得我们感觉是多个任务同时进行,其实内部还是按照一定的顺序在执行每个任务。



对于单核处理器,也只能使用这种任务交换的方式来实现并发,



对于多核处理器,可以实现真正的物理并发。下面盗图演示一下

Qt C++ 并发,并行,多线程编程系列1 什么是并发

绿色表示一个独立的任务,红色表示另一个任务,当我们的处理是双核或者多核的时候,每个任务都在其中的一个核心上面独立运行,但是当我们的处理器为单核处理器时,这时系统将采用任务交换的方式来实现程序的并行执行,在这期间,会有部分时间使用来处理每个任务的保存和切换的,图中的灰色部分就是每个任务切换是的时间间隔,这个间隔是cpu将上个任务的状态保存,并且读取下个任务的状态。



计算机操作系统对于并发性和并行性的概念给出的定义是:

并行性是指两个或多个事件在同一时刻发生;

并发性是指两个或多个事件在同一时间段内发生。



所以,在我看来,并行,就是两个人操作两个机器,而并发就是一个人同时操作两个机器。




写的不好,欢迎指正。


Qt C++ 并发,并行,多线程编程系列1 什么是并发Qt C++ 并发,并行,多线程编程系列1 什么是并发Qt C++ 并发,并行,多线程编程系列1 什么是并发Qt C++ 并发,并行,多线程编程系列1 什么是并发Qt C++ 并发,并行,多线程编程系列1 什么是并发Qt C++ 并发,并行,多线程编程系列1 什么是并发Qt C++ 并发,并行,多线程编程系列1 什么是并发

上一篇:eclipse学习(第二章:初识ssh)——15.Struts2的主题和模板(了解就好了)


下一篇:windows 2008 R2搭建FTP服务器(续——用户隔离)