单进程单线程
一个小明吃100个蛋糕肯定吃不完,效率很低.而且小明可能会被撑死 😄
多进程单线程
为了加快吃草莓蛋糕的速度,我们采用并发编程,采用多进程单线程的方式.就是说有两个房间和桌子,然后让小明的兄弟小跳去另一件房子吃50个草莓蛋糕,帮小明分担了50个草莓蛋糕.这时这俩兄弟互相不知道对方吃的多快,这就叫进程之间的数据是不共享的(进程的隔离性).
单进程多线程
和上一个版本相比,吃的效率高了很多,而且资源也没有额外消耗很多.这时这俩兄弟知道对方吃的多快,这就叫同一个进程中的若干个线程是共享资源的.
多进程多线程
此时并发程度进一步提高了,要比上一个版本执行效率更快了.
这种方式其实不是很有必要,可以有替代方式,此时,并发程度是一样的(都是四个哥俩吃蛋糕),但是资源消耗更小
进程中的线程
一个进程中的线程时越多越好么?不是的.就好比,100个草莓蛋糕不是说越来越多的人来吃就好,当小明的数量太多的时候,此时再创建新的小明,也够不上桌子,并发能力也就达到了上限,继续增加线程也不会再提高效率,甚至可能反而拖慢效率(线程调度也是有开销的)
问:一个进程做多能搞多少个线程呢?
1.CPU的个数相关
2.和线程执行的任务的类型也相关
3.任务类型:分两个类型:CPU密集型(程序就一直在执行计算任务);IO密集型:程序没咋进行计算,主要是进行输入输出操作
多线程的问题
1.假如小明和小跳同时看上一块蛋糕,两个人同时去抢,随时就可能打起来,这就叫"线程不安全".
2.好几个小明一起吃蛋糕,其中一个小明生气了,就掀桌了想报复社会,此时其他的小明也就吃不了蛋糕了这就叫:一个线程如果抛出异常,并且也没有很好的处理这个异常的话,整个进程就会被直接终止,此时其他线程也就没法继续工作了.