1、操作系统
现代操作系统都可以执行多任务
操作系统轮流让多个任务交替运行,让人感觉就好像在同时执行多个任务。
2、进程
在计算机里一个任务就是一个进程,进程是操作系统进行资源分配和调度的一个独立单位,是应用程序运行的载体。
3、线程
进程内部还需要同时执行多个子任务,这些子任务被称为线程
一个程序里不同的执行路径,就是一个线程
4、进程和线程之间的关系
- 一个进程可以包含一个或多个线程(至少一个线程)
- 线程是操作系统调度的最小任务单位
- 如何调度线程完全由操作系统决定
5、实现多任务的方法
- 多进程模式(每个进程只有一个线程)
- 多线程模式(一个进程有多个线程)
- 多进程+多线程模式(复杂度最高)
6、多进程vs多线程
- 创建进程比创建线程开销大
- 进程间通信比线程间通信慢
- 多进程稳定性比多线程稳定性高(多进程模式,某个进程崩溃不会影响其他进程;但多线程模式,一个线程的崩溃会导致这个进程的崩溃)
7、java多线程
java语言内置多线程支持环境
- 一个java程序实际上是一个jvm进程
- jvm用一个主线程来执行main()方法
- 在main()方法中可以启动一个或多个线程
8、多线程编程的特点
- 多线程需要读写共享数据
- 多线程经常需要同步
- 多线程编程复杂度较高,调试困难
多线程模型是java程序最基本的并发模型。