1. 线程和进程的关系和区别
1. 线程的定义
- 线程是进程的基本执行单元,一个进程的所有任务都在线程中执行
- 进程想要启动,必须要有线程,进程只需要有一条线程
- 程序启动会默认开启一条线程,这条线程会被成为主线程
2. 进程的定义
- 进程是指在系统中正在运行的一个应用程序
- 每个进程之间都是独立的,每个进程都运行在其专用的,且都保护的内存区域
3.进程和线程的区别
- 地址空间
同一进程的线程共享本进程的地址空间,而进程之间则是独立的地址空间
- 资源拥有
- 同一进程内的线程共享本进程的资源,内存,I/O,cpu等,但是进程之间的资源是独立的.
- 一个进程崩溃后,在保护模式下不会对其它进程产生影响,但是一个线程崩溃后整个进程都会死掉,所有多进程比多线程健壮
- 进程切换时,消耗的资源大,效率低.所以涉及到频繁切换时,使用线程要好于进程.同样如果要求同时进行并且又要共享默认写变量的并发操作,只能用线程不能用进程.
- 执行过程
每个独立的进程都有一个程序运行的入口,顺序执行序列和程序入口.但是线程不能独立运行,必须依存在应用程序中,由应用程序提供多个线程执行控制
- 线程是处理器调度的基本单位,但是进程不是
2. 多线程的意义
- 优点 :
- 能适当提高程序的执行效率
- 适当的提高资源的利用率(cpu,内存)
- 线程上的任务执行完成后,线程会自动销毁
- 缺点 :
- 开启线程需要占用一定的内存空间(默认情况下占用512K)
- 如果开启了大量的线程 ,会占用大量的内存空间,降低程序的性能
- 线程越多,cpu在调用线程上的开销就越大
- 程序设计更加复杂,比如线程之间的通信,多线程的数据共享
3. 线程的生命周期
4.线程池调度原理
5. 容易混淆的术语
- 同步和异步
- 影响能不能开启新的线程
同步 : 在当前线程中执行任务,不具备开启新线程的能力
异步 : 在新的线程中执行任务,具备开启新的线程的能力
- 并发和串行队列
- 任务的执行方式
并发 : 多个任务并发(同时)执行
串行 : 一个任务执行完毕后,在执行下一个任务