进程与

线程

1)一个进程内部的一个执行单元,它是程序中的一个单一的顺序控制流程。
2)一个进程可拥有多个并行的(concurrent)线程。
3)一个进程中的多个线程共享相同的内存单元/内存地址空间,可以访问相同的变量和对象,而且它们从同一堆中分配对象并进行通信、数据交换和同步操作。
4)由于线程间的通信是在同一地址空间上进行的,所以不需要额外的通信机制,这就使得通信更简便而且信息传递的速度也更快。
5)线程的启动、中断、消亡,消耗的资源非常少。

线程和进程的区别

1)每个进程都有独立的代码和数据空间(进程上下文),进程间的切换会有较大的开销。
2)线程可以看成是轻量级的进程,属于同一进程的线程共享代码和数据空间,每个线程有独立的运行栈和程序计数器(PC),线程切换的开销小。
3)线程和进程最根本的区别在于:进程是资源分配的单位,线程是调度和执行的单位。
4)多进程: 在操作系统中能同时运行多个任务(程序)。
5)多线程: 在同一应用程序中有多个顺序流同时执行。
6)线程是进程的一部分,所以线程有的时候被称为轻量级进程。
7)一个没有线程的进程是可以被看作单线程的,如果一个进程内拥有多个线程,进程的执行过程不是一条线(线程)的,而是多条线(线程)共同完成的。
8)系统在运行的时候会为每个进程分配不同的内存区域,但是不会为线程分配内存(线程所使用的资源是它所属的进程的资源),线程组只能共享资源。那就是说,除了CPU之外(线程在运行的时候要占用CPU资源),计算机内部的软硬件资源的分配与线程无关,线程只能共享它所属进程的资源。

猜你喜欢

转载自blog.csdn.net/mys_mys/article/details/83687798
今日推荐