进程和线程的那些事
- 进程是系统分配资源的最小单位,线程是系统调度的最小单位。一个进程内的线程之间是可以共享资源的。
- 一个线程只能属于一个进程,而一个进程可以有多个线程,但至少有一个线程,即主线程。
自己的看法:前面聊到了进程,所以在这不多做解释。自己对线程的理解是,一组操作,后边会写到线程的代码,站在程序的角度理解线程就更明白了。
与线程相关的小知识
① 时间片
操作系统(如Windows、Linux)的任务调度是采用时间片轮转的抢占式调度方式,也就是说一个任务执行一小段时
间后强制暂停去执行下一个任务,每个任务轮流执行。
任务执行的一小段时间叫做时间片,任务正在执行时的状态叫运行状态,任务执行一段时间后强制暂停去执行下一个
任务,被暂停的任务就处于就绪状态等待下一个属于它的时间片的到来
② 并发与并行
并发 : 多个进程在一个CPU下采用时间片轮转的方式,在一段时间之内,让多个进程都得以推进,称之为并发。
并行 : 多个进程在多个CPU下分别,同时运行,称 之为并行
线程状态转移图
英文版
中文版
线程的作用
使多个程序并发执行,(有可能会)提高执行效率
线程的不安全性
①原子性
对于涉及共享变量的访问操作,若该操作从其执行线程以外的任意线程来看是不可分割的,那么该操做就是原子操作,我们称之为原子性的
②内存可见性
如果一个线程对共享变量值的修改,能够及时被其它线程看到,则称这个共享变量在线程之间是可见的
③代码重排
在执行程序时,为了提高性能,编译器和处理器常常会对指令做重排序。