一、进程与线程
- 进程与线程
- 进程指运行中的程序
- 线程是CPU的基本调度单位,每个线程执行的都是某一个进程代码中的片段
- 进程就是线程的“容器”,一个进程起码有一个线程。
- 进程与线程的区别
- 根本不同:进程是操作系统分配的资源,线程是CPU调度的基本单元
- 资源方面:不同进程之间资源不共享。同一个进程下,线程是共享进程资源的。线程有自己独立的存储空间,这个是在cpu里面的,缓存么。
- 数量不同:进程一般就指一个进程,一个进程拥有一个或者多个线程
- 开销不同:线程的创建、终止、切换很快,进程做这些操作的时候很慢
二、多线程
- 多线程就是指一个进程中运性多个线程
- 多线程的目的其实就是要充分利用我们的CPU
- 多线程的缺点:
- 线程上线文切换消耗资源
- 有些任务、场景是无法用多线程解决的
- 多线程会引起数据不一致的问题
三、串行、并行、并发
- 串行:一个挨着一个执行
- 并行:多个CPU同时执行多个任务
- 并发:其实是对于CPU来说的,多个线程同时在一个cpu上跑任务,线程切换时间很短,你看出来,就类似成了所谓的并发
四、同步、异步、阻塞、非阻塞
- 对于被调用者来说:同步、异步
- 同步:执行某个功能后,不会主动返回结果
- 异步:执行某个功能后,会主动返回结果
- 对于调用者来说:阻塞、非阻塞
- 阻塞:执行某个功能后,调用者需要等待返回结果
- 非阻塞:执行某个功能后,调用者不需要等待返回结果
- 同步阻塞:用锅烧开水,你站在哪里等待开始烧开
- 同步非阻塞:用锅烧开水的时候,你可以忙别的,只不过需要不时的来看一下水烧开了么
- 异步阻塞:这是最蠢的,电子水壶烧开水的时候,你站在哪里等在水烧开,而且水壶会给你反馈水烧开了
- 异步非阻塞:这是最好的,电子水壶烧开水的时候,你去干别的,水壶烧开了会通知你