一:名词解释
进程:Process
线程:thread
CPU:计算机的核心和大脑,主要用来取指--解码--执行操作
1、抽象理解CPU为一个工厂,工厂的生产能力有限(受硬件和系统限制),一次只能提供一个车间使用,单核CPU就只能运行单个任务
2、进程就好比工厂的车间,每个车间完成不同的任务
3、线程就好比车间的工人,一个车间可以有单个工人,也可以有多个工人协同完成一个任务。所以一个进程可以包含多个线程
4、车间中的空间是工人共享的,象征着进程中的内存是共享的,每个线程都可以使用这些内存;
5、每个房间的大小不同,有些只能供一个人使用,比如厕所,只能满足一个人使用时,另外的人等待。这就意味着,一个线程使用某些共享内存的时候,其他线程处于线程等待状态;
6、防止厕所被他人进入的办法,就是关门上锁。先到的人使用,并上锁,后面的人等锁打开后才能进入,这叫“互斥锁”(Mutual exclusion),也叫mutex防止多个线程同时读写某一块内存区域;
7、还有些房间,可以同时容纳n个人使用,比如厨房,可以满足固定n个人同时协同使用,多出来的人进行等待。就像一块内存,只能供给固定数目的线程使用;
8、为防止线程过多导致流水线拥堵,解决办法就是门口挂n把钥匙,进去的人取走一把,出来再放回原处,后来的人发现门口没有钥匙,就进行等待,这个就叫“信号量”(Semaphore);用来保证多个线程不会互相冲突;可以看出mutex是特殊的一种Semaphore,但是效率更高,如果在保证单独使用资源的时候,可以使用这种设计(厕所)
9、一个车间多个工人共同完成一个生产,相当于一个进程的多个线程协同完成;