Linux -- 初识线程

目录

线程的初步认识

为什么需要线程

怎么让代码分成多个执行流并发执行呢?

管理线程 


线程的初步认识

线程是进程内部的一个执行分支,线程是CPU调度的基本单位。

在Linux操作系统中,线程是程序执行流的最小单位。一个进程可以包含多个线程,这些线程共享进程的资源,如内存空间、文件描述符等,但每个线程有自己的程序计数器、栈和栈指针。这使得多线程程序能够并行执行多个任务,从而提高程序的效率和响应性。

为什么需要线程

在过去,我们认为在一个进程中,正文代码中的函数是串行调用的,如下图所示,我们认为

  1. 调用 A,执行完成后返回。
  2. 调用 B,执行完成后返回。
  3. 调用 C,执行完成后返回。
  4. 调用 D,执行完成后返回。

如果任务中有耗时的操作(如 I/O 操作、网络请求等),串行调用会让整个程序的执行速度受到影响。 

如下图,如果我们把代码分成两个执行流调用,即并行调用,多个任务可以同时执行,而不是一个接一个地执行,可以大大减少总的执行时间

怎么让代码分成多个执行流并发执行呢?

我们需要知道,创建一个子进程,实际上也是创建了一个执行流,父子进程相互独立,各自执行自己的代码。在创建子进程时,需要给子进程设置进程地址空间、创建页表等,这些操作的开销比较大。也就是说,如果创建多个进程来让代码分成多个执行流并发执行,其开销是比较大的。

从另一个角度想,同一个可执行程序创建多个进程,分成多个执行流并发执行,并没有必要让所有的执行流都私有一份地址空间和页表,因为每个执行流看到的进程地址空间和页表内的数据都是一样的,对同一份资源拷贝多次,消耗了时间和空间。

我们只需要创建出多个 task_struct ,让这些 task_struct 都指向同一个进程地址空间,就可以省下这些开销。如下图所示:

如果把代码区的代码分成三部分,A进程执行第一部分,B进程执行第二部分,C进程执行第三部分,这样就实现了代码分成多个执行流并发执行! 现在需要修正一下,其实A、B、C进程也就是线程。

 所以线程是进程内部的一个执行分支,也就是说,我们之前认为的进程,其实是内部只有一个线程的进程,而今天理解的进程,是内部至少有一个线程的进程!

管理线程 

有了线程,就需要对线程进行管理,操作系统要创建线程、标识线程、按照优先级调度线程、要对线程进行上下文保护、要释放线程、回收相关的资源,对线程的管理方式其实和进程的管理方式是相似的,而且线程和进程都是执行流,在 Linux 的设计者认为,没有必要为了管理线程单独设计数据结构和算法,直接复用进程的相关代码即可!

那么CPU在调度时,不用管 task_struct 是进程还是线程,只要调度就好了,因为进程和线程都是执行流,反过来,CPU在调度时,拿到的执行流可能是进程,也可能是线程,Linux中没有物理意义的线程,所以在Linux中,执行流也叫轻量级进程

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/6084.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

基于IM场景下的Wasm初探:提升Web应用性能|得物技术

一、何为Wasm ? Wasm,全称 WebAssembly,官网描述是一种用于基于堆栈的虚拟机的二进制指令格式。Wasm被设计为一个可移植的目标,用于编译C/C/Rust等高级语言,支持在Web上部署客户端和服务器应用程序。 Wasm 的开发者参…

Linux SSH免密登入以及配置脚本

一、ssh原理简单介绍 客户端生成一对公钥和私钥,并将自己的公钥发送到服务器上 其中公钥用来加密,私钥用来解密。 二、ssh免密登入实现步骤详解 我这就以服务器controller和客户端compute来做为例子 2.1、首先在controller上输入ssh-keygen -t rsa …

Flutter 获取照片权限的时候是否要获取存储权限?

获取存储权限 Permission.storage.request(); 获取照片权限通常意味着访问相册,而访问相册可能还需要外部存储权限,因为照片通常存储在设备的外部存储中。所以,当你请求照片权限时,你也需要检查并请求外部存储权限。 是不是所有…

一个基于Rust适用于 Web、桌面、移动设备等的全栈应用程序框架

大家好,今天给大家分享一个用 Rust 语言编写的、受 React 启发的前端框架Dioxus,旨在为构建跨平台的用户界面提供高效、高性能的解决方案。 项目介绍 Dioxus项目的诞生源于开发者们对于更高效、更灵活的跨平台UI解决方案的渴望。 随着技术的发展&#…

IntelliJ Idea设置自定义快捷键

我IDEA的快捷键是自己修改成了和Eclipse相似,然后想要跳转到某个方法的上层抽象方法没有对应的快捷键,IDEA默认的是Ctrl U (Windows/Linux 系统) 或 Command U (Mac 系统),但是我的不起作用&a…

前深度学习时代-经典的推荐算法

参考自《深度学习推荐系统》—— 王喆,用于学习记录。 1.协同过滤 “协同过滤”就是协同大家的反馈、评价和意见一起对海量的信息进行过滤,从中筛选出目标用户可能感兴趣的信息的推荐过程。 基于用户相似度进行推荐的协同过滤算法 UserCF 用户相似度…

达梦数据守护集群_动态增加实时备库

目录 1、概述 2、实验环境 2.1环境信息 2.2配置信息 2.3 查看初始化参数 3、动态增加实时备库 3.1数据准备 3.2配置新备库 3.3动态增加MAL配置 3.4 关闭守护进程及监视器 3.5修改归档(方法1:动态添加归档配置) 3.6 修改归档&…

6.qsqlquerymodel源码分析

目录 继承关系入口浅析qsqlquery刷新数据 扩展列或者移除列以及取别名读取数据与增减行读取数据 下一章节:如何使用qsqlquerymodel 与 qtableview实现自定义表格 继承关系 qsqlquerymodel 继承与qabstracttablemodel 入口 负责填充数据 void QSqlQueryModel::s…

【JavaEE】认识线程

一、引入线程 在任务管理器界面可以看到很多进程,可以利用CPU多核心这一点来更有效的执行这些进程,即在处理过程中将CPU的多个时间片分配给每个进程,这样的 "多进程编程"就可以起到并发编程的效果,因为进程可以被调度到…

qt QStatusBar详解

1、概述 QStatusBar是Qt框架提供的一个小部件,用于在应用程序窗口底部显示状态信息。它可以显示一些固定的文本和图标,并且可以通过API动态更新显示内容。QStatusBar通常是一个水平的窗口部件,能够显示多行文本内容,非常适合用于…

【Ubuntu】ubuntu 22.04 设置 Xorg 弃用 Wayland

# 编辑gdm3配置文件 sudo vim /etc/gdm3/custom.conf # 重启gdm3 sudo systemctl restart gdm3方式一:如果进行上述操作后,有对比度严重错误问题,请执行下列命令 # 安装驱动 sudo ubuntu-drivers autoinstall 方式二:推荐尝试方式…

日语学习的难易程度

日语学习的难易程度是一个相对主观的问题,它受到多种因素的影响,包括个人的语言学习能力、学习方法、学习时间、学习资源的可获得性以及个人对日语文化的兴趣和投入程度等。以下是对日语学习难易程度的一些分析: 优点与易学之处 文字系统&am…

WPF 打包

打包为单个exe文件直接运行 - - -版本.NET8 新建WPF项目 右键 - 发布 选择发布文件夹 选择发布文件夹 选择发布文件夹 配置 配置,保存 发布 WPF 打包为exe安装程序 示例 实现思路 引导项目中嵌入其它项目可运行目录的zip引导项目中解压zip文件到指定文件夹是…

RTC精度及校准

RTC精度偏差: RTC的基准时间和精度与石英晶体的频率相关,晶体的谐振频率取决于温度,因此RTC性能与温度相关,晶体的频率偏差是晶体正常频率的温度反转函数。 一、硬件方面: 1.使用高精度振荡器的RTC模块; …

C++ Qt6 QtQuick/QML入门进阶与项目实战视频教程

课程介绍 C Qt这些年在PC客户端、嵌入式、汽车座舱仪表等领域应用很广泛,例如剪映专业版、微信4.0、亿图脑图、Steam、美图秀秀、腾讯会议、钉钉(部分模块)等都是使用C QWidget/QML开发。特别是QML这种声明式UI开发更加快捷,QML的界面开发效率相对于QWid…

Linux:防火墙和selinux对服务的影响

1-1selinux 1-1 SELinux是对程序、文件等权限设置依据的一个内核模块。由于启动网络服务的也是程序,因此刚好也 是能够控制网络服务能否访问系统资源的一道关卡。 1-2 SELinux是通过MAC的方式来控制管理进程,它控制的主体是进程,而目标则是…

逻辑回归处理非线性关系与支持向量机的性能对比

逻辑回归是一种常用的线性分类方法,通常用于处理线性关系的二分类任务。但是,对于非线性问题,传统的逻辑回归模型可能表现不佳,因为它假设数据可以被一个线性决策边界分割开来。为了使逻辑回归能够处理非线性关系,我们…

2021数二第9题 线代 一个方程组的解是另一个方程组的解

题目展示的是一个方程组的列向量 可由另一个列向量表示所以是矩阵的转置

C#与C++交互开发系列(二十):跨进程通信之共享内存(Shared Memory)

1、前言 共享内存(Shared Memory)是一种高效的跨进程通信方式,尤其适用于同一台计算机上的进程之间的高速数据传输。与套接字相比,共享内存允许多个进程直接访问同一块内存区域,减少了数据传输的中间步骤,…

防火墙|WAF|漏洞|网络安全

防火墙|WAF|漏洞|网络安全 防火墙 根据内容分析数据包: 1、源IP和目的IP地址 2、有效负载中的内容。 3、数据包协议(例如,连接是否使用 TCP/IP 协议)。 4、应用协议(HTTP、Telnet、FTP、DNS、SSH 等)。 5…