进程和线程的定义和区别

1、进程定义

进程:是具有一定独立功能的程序关于某个数据集合上的一次进行活动,是系统进行资源分配和调度的一个独立单位。

 

2、线程定义

线程:是进程的一个实体,是cpu调度和分派的基本单位,他是比进程更小的能够独立运行的基本单位,线程自己基本上不拥有系统资源,只拥有一点在运行中必不可少的资源。一个线程可以创建和撤销拎一个线程。

 

区别:

1、一个线程只能属于一个进程,而一个进程可以拥有多个线程。

2、线程是进程工作的最新单位。

3、一个进程会分配一个地址空间,进程与进程之间不共享地址空间。即不共享内存。

4、同一个进行下的不同的多个线程,共享父进程的地址空间。

5、线程在执行过程中,需要协助同步。不同进程的线程间要利用消息通信的办法实现同步。

6、线程作为调度和分配的基本单位,进程作为拥有资源的基本单位。

 

进程的优点:

1、每个进程互相独立,不影响主程序的稳定性,子进程崩溃不影响其他进程。

2、通过增加CPU,就可以扩充性能。

3、可以尽量减少线程加锁与解锁的影响,极大的提高了性能。

 

进程的缺点:

1、逻辑控制复杂,需要和主程序交互。

2、多进程调度开销大。

 

线程的优点:

1、程序逻辑和控制方式简单。

2、所有线程可以直接共享内存和变量等。

3、线程方式消耗的总资源比进程方式少。

 

线程的缺点:

1、每个线程和主程序共用地址空间,最大内存地址受限。

2、线程之间的同步和加锁不易控制。

3、一个线程的崩溃可能影响到整个程序的稳定性。