C | 进程和线程的区别 1.概念: 进程是程序为了完成任务执行的一次过程,是一个动态的。进程包括两个集合。一个资源的集合,一个线程的集合。 线程是进程的进一步抽象。线程本质是运行一个线程函数,线程是轻量级进程,每个进程中必然包括一个线程,被称为主线程。
2.调度: 进程是资源分配的最小单位。线程是系统调度的最小单位。
3.安全性: 进程在启动初期会申请一个0-4G的虚拟空间。3-4G是内核空间,多进程之间共享,用于进程间通信。0-3G是用户空间,每个进程都有独立的用户空间,互不影响,所以安全性更高。 同一个进程内的线程共享进程的资源,其中一个线程崩溃可能会对其他线程造成影响,多线程安全性差。线程中应避免对共用的资源操作,以免进程崩溃。
4.创建: 创建进程使用fork函数。进程个数没有限制。 线程不属于标准c库函数也不属于系统调用,而是属于第三方库libpthread.so。创建线程使用pthread_creat函数。线程个数是有限。
5.通信: 进程间通信方式有:无名管道,有名管道,信号,消息队列,共享内存,信号灯集,socket套接字通信。 线程间通信方式有两种,全局变量和参数arg。多线程间通信简单,但是需要对临界资源进行互斥与同步操作。
6.资源:进程会申请一个PCB进程控制块,它是一个结构体(task_struct),里面存储了进程所有的资源。如:PC程序计数器、堆栈、文件描述符、进程的状态 、进程号等等。 线程也属于并发,也会拥有自己的资源,但线程本身并不会去申请资源 ,而是共享进程的资源。
7.运行速度:进程较大,速度相对较慢。线程速度快。
8.调度机制: 进程是时间片轮询,上下文切换。进程之间存在着一种竞态。执行速度是不一定的,所以父子进程结束的快慢也是不一定。 线程间的同步机制:无名信号量;互斥机制:互斥锁(与条件变量配合使用)。
|