进程(process)和线程(thread)
- 进程和线程独立运行,并可能同时运行,多个线程能够共享单个进程的内存。
- 进程是具有一定独立功能的程序,它是系统进行资源分配和调度的一个独立单位,重点在系统调度和单独的单位,换句话说进程是可以独立运行的一段程序。
- 线程是进程得一个实体,是 CPU 调度和分派的基本单位,他是比进程更小的独立运行的基本单位,线程自己基本上不拥有系统资源。在运行时,只是暂用一些计数器、寄存器和栈。
他们之间的关系是
- 一个线程只能属于一个进程,而一个进程可以有多个线程,但至少有一个线程(就是通常说的主线程)
- 资源分配给进程,同一进程的所有线程共享该进程的所有资源
- 线程在执行过程中,需要协作同步。不同进程的线程间要利用消息通信的方法实现同步。
- 处理机分给线程,即真正在处理机上运行得是线程
- 线程是指进程内的一个执行单元,也是进程内的可调度实体
他们之间的区别
- 调度:线程作为调度和分配的基本单位,进程作为拥有资源的基本单位
- 并发性:不仅进程之间可以并发执行,同一个进程的多个线程之间也可以并发执行。
- 拥有资源:进程是拥有资源的一个独立单位,线程不拥有系统资源,但也可以访问隶属于进程的资源。
生动形象
- 书面上,进程和线程基本是一个东西,只是进程可以包含若干个线程。此外就是在操作系统中的层级上,也就是粒度不同外,没有其他大的区别。在一般使用中,需要就多开几个线程。
- 形象的说,进程就是一个项目组,每个程序员就是里面的线程,当然一个程序员也可以是一个项目组,对应的一个进程只有一个线程,而且还是主线程。公司里面的任务是分配给项目组级别的,也就是说系统资源是分配给进程的,但是干活的是程序员(线程)。