进程与线程
进程(Process)
程序是指令和数据的有序集合,而进程是程序的一次执行过程,是一个抽象的概念。是系统资源分配的单位。
线程(Thread)
通常一个进程可以包含多个线程,当然的一个进程至少包含一个线程。线程是CPU调度和执行的单位。
线程的概念
- 线程就是独立的执行路径;
- 在程序运行时,即使没有自己创建线程,后台也会有多个线程,如主线程,gc线程;
- main()称之为主线程,为整个系统的入口,用于执行整个系统;
- 在一个进程中,如果开辟了多个线程,线程的运行由调度器安排调度,调度器是与操作系统紧密相关的,先后顺序是不能认为的干预;
- 多线程下对同一份资源操作时,会存在资源抢夺的问题,需要加入并发控制;
- 线程会带来额外的开销,如cpu调度花费的时间,还有并发控制产生的时间开销;
- 每个线程在自己的工作内存交互,内存控制不当会造成数据不一致;