1、多线程
- 多次按执行路径,主线程与子线程并行交替执行(普通方法之一主线程一条路径)。
- 很多线程是模拟出来的,真正的过线程是指有多个CPU,即多核,如服务器。
- 如果是模拟出来的多线程,即在一个CPU的情况下,在同一个时间点CPU只能执行一个代码,因为切换的很快,所以就有同时执行的错觉。
2、程序
- 指令和数据的有序集合,本身没有任何运行的含义,是一个静态的概念。
3、进程
- 在操作系统中运行的程序就是进程,即执行程序的一次执行过程,是一个动态的概念。
- 一个进程可以有多个线程,比如视频中同时听声音,看图像,看弹幕等。
- 同一个进程中,如果开辟了多个线程,线程的运行是由调度器(CPU)安排调度的,调度器是与操作系统紧密相关的,先后顺序是不能人为干预的。
4、线程
- 独立的执行路径,CPU调度和执行的基本单位。
- 程序运行期间即使没有创建线程,后台也会有多个线程,如主线程、GC线程。
- 对同一个资源操作的时候,会存在资源抢夺问题,需要加入并发控制。
- 线程会带来额外的开销,如CPU调度时间,并发控制开销。
- 每个线程在自己的工作内存交互,内存控制不当会造成数据不一致。
5、主线程
- main()是主线程,程序的入口,用于执行整个程序。