进程与线程的基本概念

多线程之基本概念

1.      进程的概念

进程是运行程序的实体,在面向进程的系统中,进程是程序的基本执行实体,而在面向线程的系统中,进程是线程的容器;

程序本身是指令,数据及其组织形式的描述,而进程是程序的运行实体。

2.     线程的概念

线程是操作系统能够调度的最小单位,被包含在进程中,是进程中的实际运作单位,一个线程指的是一个进程中的单一顺序的控制流,一个进程可以包含多个线程,多个线程可以同时执行;

    同一进程中的多个线程共享该进程的全部系统资源,但是每个线程拥有各自的调用栈,寄存器环境和本地存储

3.     进程的建立

System()

在进程中创建子进程,相当于调用shell(bin/sh)。

Fork()函数

后面重点讲解

Exec()族

立即执行子程序,不返回

4.      进程与线程的对比

ü  所有的线程执行同一个可执行文件,即在同一个程序下执行;一个进程的子进程可以通过调用exec()函数执行其它的程序;

ü  当一个线程出错时,会影响到同一进程下的所有线程,因为他们共享存储空间,但是每个进程都拥有不同的存储空间,所以进程间不会相互干扰;

ü  创建新的进程需要复制原有的存储,但是复制只发生在内存改变的情况下,如果只进行读取操作,消耗就比较小;

ü  线程一般运用在需要更小操作颗粒度的程序,如一个可以分为相同的小问题的大问题,比如网络爬虫;进程一般使用于更高颗粒度的情况。

ü  两者都有并发的问题存在

进程线程操作系统中的两个基本概念,它们都是用来执行程序的执行单元,但在一些方面有着明显的区别。 1. 进程(Process): - 进程是程序在执行过程中的一个实例。 - 每个进程都有自己的独立内存空间,包括代码段、数据段和堆段。 - 进程之间相互独立,拥有各自的资源,通信需要通过进程间通信(IPC)机制。 - 进程拥有自己的进程控制块(PCB),用于描述进程的状态、资源和调度信息。 2. 线程(Thread): - 线程进程中的一个执行单元。 - 多个线程可以共享同一个进程的内存空间,包括代码段、数据段和堆段。 - 线程之间共享进程资源,如打开的文件、信号处理等。 - 线程线程控制块(TCB)来描述,每个线程有自己的寄存器上下文。 区别: 1. 资源占用:每个进程都有独立的内存空间和系统资源,而线程共享进程资源。 2. 创建销毁开销:创建或销毁进程线程开销大,因为进程需要分配独立的内存空间和系统资源,而线程只需要创建线程控制块。 3. 切换开销:进程切换的开销较大,需要保存和恢复整个进程的上下文,而线程切换只需要保存和恢复线程的上下文。 4. 通信和同步:进程间通信需要使用进程间通信机制,如管道、消息队列等。线程间通信和同步相对容易,可以使用共享内存、信号量、互斥量等机制。 总结: 进程线程都是用于执行程序的执行单元,但进程资源分配的基本单位,线程是CPU调度的基本单位。多线程比多进程更轻量级,线程之间的切换开销更小,但进程之间相互独立,安全性更高。在实际应用中,需要根据具体需求选择使用进程还是线程
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值