线程基本概念

线程概念

a.程序当中的一个执行路线
b.进程当中的一个控制序列
c.一个进程至少有一个执行线程

Linux中的线程是通过进程模拟实现线程的,没有真正意义的线程
Linux中的进程称为轻量级进程至少有一个执行线程

进程与线程

进程是承担分配系统资源的基本单位实体
线程是调度的基本单元,程序执行的最小单位
进程之间数据独立;
线程共享进程资源,独自拥有自己的上下文数据和私有栈结构
一个进程的地址空间被多个线程共享,共享文件描述符,信号处理方式,当前目录,用户id和组id。
进程有一个进程控制块(PCB) 线程也有一个线程控制块(TCB)

线程优点(和进程相比)

1.创建更加简单,所需要的系统资源更少
2.线程的相互切换更加容易,相较于进程的切换,线程切换不用切换页表
3.占用资源少(比进程少了虚拟地址空间、页表等等…)
4.能充分利用多处理器的可并行数量
5.计算密集型应用(一直调用CPU计算数据):为了在多处理器系统上运行,一般采用多线程方式,将计算分解到多个线程中实现
6.I/O密集型应用(一直调用I/O资源):为提高性能,将I/O操作重叠,让线程来同时等待不同的I/O操作。

线程缺点(和进程相比)

1.对于计算密集型线程,会造成性能缺失(增加额外的同步和调度开销)
2.健壮性降低:一个线程出现异常会影响其他线程的运行。
3.缺乏访问控制:进程是访问控制的基本粒度
4.代码复杂度更高,更难编写代码

多线程进程图示:
在这里插入图片描述

都是硬知识,干货。。。
了解即可。。
在这里插入图片描述

进程线程是操作系统中的两个基本概念,它们都是用来执行程序的执行单元,但在一些方面有着明显的区别。 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、付费专栏及课程。

余额充值