1.什么是线程
一个线程就是一个 "执行流",每个线程之间都可以按照顺讯执行自己的代码,多个线程之间 "同时" 执行 着多份代码。
之前说进程相当于一个任务,我们可以举一个例子来描述一下进程和线程之间的关系,我们将一个工厂称为一个进程,工厂中有很多条流水线,每条流水线都在生产一个汽车不同部位的零件,将这些流水线上的零件组合起来就能形成一辆汽车。这时候,我们可以称每一条流水线为一个线程,整个工厂为一个进程。
上面的这种情况我们就称为多线程,将一个大的任务分解为多个小任务,然后分配给不同的执行流去完成。
2.为什么要有线程
还是拿生产汽车零件的例子来说,现在有很多个工厂,每个工厂只有一条流水线,生产汽车不同部位的零件,最后将这些工厂生产出来的零件也能组装成一辆汽车,既然这样也可以,那线程的存在意义上什么呢?
1."并发编程"成为"刚需"
- 单核CPU的发展已经遇到了瓶颈,要进一步提高算力,就需要多核CPU,并发编程能更充分的利用多核CPU的资源
- 某些场景需要"等待IO",为了让等待的时间可以去做一些其他的事情,也需要用到并发编程
2.虽然多进程也能实现并发编程,但是线程比进程更轻量
- 创建线程比创建进程更快
- 销毁线程比销毁进程更快
- 调度线程比调度进程更快
3.进程和线程的区别
- 进程包含线程,每个进程至少有一个线程,即主线程
- 进程和进程之间不共享内存空间,同一个进程的线程之间共享同一个内存空间
- 进程是系统分配资源的最小单位,线程是系统调度的最小单位