Linux的学习之路:21、线程(1)

摘要:

本章说一下线程

目录

摘要:

一、回忆一下

二、如何理解线程

三、命令行看线程

四、利用函数进行使用

五、本章总结

1、线程的优点

2、线程的缺点

3、线程的异常

4、线程的用途


一、回忆一下

1、exe就是一个文件

2、我们的可执行程序本来就是按照空间方式进行编译的

3、可执行程序,其实就是按照区域也就是已经被划分成了以4kb为单位的大小

六字真言:先描述在组织,如下图就是先描述在组织,产生的stack_struct的结构体,这个存着虚拟地址,然后虚拟地址存着用户级页表,然后页表里面存着物理内存,然后物理内存存在磁盘内。

 那么数据如果很多该怎么存入呢?如下图在32位环境下,是通过前面十位0就是指向一级页表,然后中间十位指向二级页表,其中的一级页表也指向二级页表,然后两个都一样就是二级页表,然后二级页表指向物理内存,这时找到了变量存在的地址,然后后面12位就是指向物理内存的偏移地址,所以就可以得出

page start addr + 页内偏移

通过一级页表+二级页表找到对应的页,再通过最后12位找到准确的地址,也就是偏移量

二、如何理解线程

通过一定的技术手段,将当前进程的资源,以一定的方式划给不用的task_struct,不去申请地址空间,需要什么资源就直接向主线程要,线程在内部执行,是OS调度的基本单位

这个是Linux特有的方案:没有独立的结构体

在内核视角中:

进程:承担分配系统资源的基本实体

用户视角:该进程对应的代码+资源

内部只有一个执行流的进程,但是内部具有各个执行的进程就是线程

在CPU视角中:CPU其实不怎么关心是进程还是线程这样的概念,只认识tack_struct,CPU调度的基本单位就是“线程”

在Linux下的进程:统一称之为轻量级进程,Linux并不能直接给我们提供线程的接口,只能提位轻量级进程的接口,在用户层实现了一套用户层多线程方案,以库的方式提供给用户进行使用,pathred线程库——原生线程库

三、命令行看线程

如下图利用man手册进行查看指令,pthread_create这个函数就是创建一个线程,他的参数就是下面四个

1、pthread_t *thread:这是一个指向 pthread_t 类型变量的指针,用于接收新创建的线程的标识符。

2、const pthread_attr_t *attr:这是一个指向 pthread_attr_t 类型变量的指针,用于指定线程的属性。如果设置为 NULL,则使用默认属性。

3、void *(*start_routine) (void *):这是一个指向函数的指针,该函数将作为新线程的起始执行点。这个函数通常被称为线程函数或启动例程。它接受一个 void 指针作为参数,并返回一个 void 指针。

4、void *arg:这是一个 void 指针,用于向线程函数传递参数。

如下方代码 可以看出pid都是一个,代码如下

#include <iostream>
#include <sys/types.h>
#include <unistd.h>
#include <pthread.h>
using namespace std;

void *start_routine(void *arg)
{
    while (1)
    {
        cout << "这时新进程pid: " << getpid() << " " << endl;
        sleep(1);
    }
}

int main()
{
    pthread_t tid;
    pthread_create(&tid, nullptr, start_routine, (void *)tid);
    while (1)
    {
        cout << "这时主进程,pid:" << getpid() << endl;
        sleep(1);
    }
    return 0;
}

四、利用函数进行使用

如下方代码所示就是当线程结束了,然后著进行进行打印新线程

__thread int g_val = 0;

void *threadRoutine(void *args)
{
    pthread_detach(pthread_self());
    while(true)
    {
        cout << (char*)args << " : " << g_val << " &: " << &g_val << endl;
        sleep(1);
    }
    pthread_exit((void*)11);
}

int main()
{
    pthread_t tid; 
    pthread_create(&tid, nullptr, threadRoutine, (void *)"thread 1");
    while(true)
    {
        cout << "main thread" << " : " << g_val << " &: " << &g_val << endl;
        sleep(1);
        break;
    }
    int n = pthread_join(tid, nullptr);
    cout << "n :" << n << "errstring: " << strerror(n) << endl;
    return 0;
}

五、本章总结

1、线程的优点

1、创建一个新线程的代价要比创建一个新进程小得多

2、与进程之间的切换相比,线程之间的切换需要操作系统做的工作要少很多

3、线程占用的资源要比进程少很多

4、能充分利用多处理器的可并行数量

5、在等待慢速I/O操作结束的同时,程序可执行其他的计算任务

6、计算密集型应用,为了能在多处理器系统上运行,将计算分解到多个线程中实现

7、I/O密集型应用,为了提高性能,将I/O操作重叠。线程可以同时等待不同的I/O操作

2、线程的缺点

1、性能损失
一个很少被外部事件阻塞的计算密集型线程往往无法与共它线程共享同一个处理器。如果计算密集型线程的数量比可用的处理器多,那么可能会有较大的性能损失,这里的性能损失指的是增加了额外的同步和调度开销,而可用的资源不变。

2、健壮性降低
编写多线程需要更全面更深入的考虑,在一个多线程程序里,因时间分配上的细微偏差或者因共享了不该共享的变量而造成不良影响的可能性是很大的,换句话说线程之间是缺乏保护的。

3、缺乏访问控制
进程是访问控制的基本粒度,在一个线程中调用某些OS函数会对整个进程造成影响。

4、编程难度提高
编写与调试一个多线程程序比单线程程序困难得多

3、线程的异常

1、单个线程如果出现除零,野指针问题导致线程崩溃,进程也会随着崩溃

2、线程是进程的执行分支,线程出异常,就类似进程出异常,进而触发信号机制,终止进程,进程终止,该进程内的所有线程也就随即退出

4、线程的用途

1、合理的使用多线程,能提高CPU密集型程序的执行效率

2、合理的使用多线程,能提高IO密集型程序的用户体验(如生活中我们一边写代码一边下载开发工具,就是多线程运行的一种表现)

5、进程和线程

1、进程是资源分配的基本单位

2、线程是调度的基本单位

3、线程共享进程数据,但也拥有自己的一部分数据:

        线程ID
        一组寄存器
        栈
        errno       
        信号屏蔽字
        调度优先级

4、进程的多个线程共享 同一地址空间,因此Text Segment、Data Segment都是共享的,如果定义一个函数,在各线程中都可以调用,如果定义一个全局变量,在各线程中都可以访问到,除此之外,各线程还共享以下进程资源和环境:

文件描述符表
每种信号的处理方式(SIG_ IGN、SIG_ DFL或者自定义的信号处理函数)
当前工作目录
用户id和组id

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

企业工厂如何逆风翻盘:VR全景打破多重桎梏

现阶段&#xff0c;制造业工厂面临的困境&#xff0c;就是用着上百万的设备&#xff0c;却赚着几毛钱的利润。传统的工厂参观方式也存在着很多的局限性&#xff0c;例如时间上不方便、不能实地参访、生产线具有隐患等&#xff0c;都会使得参观者不能深入地了解工厂的生产环境和…

大模型对数字营销的驱动赋能

一、大模型驱动的营销数智化个信未来发展趋势 1.模型算法能力全面升级 大模型凭借智能化的用户洞察&#xff0c;个性化的需求预测、系统化的数据分析、效率化的营销决策以及实实化的全域检测支持&#xff0c;为营销行业更加准确地把握市场动态和消费者需求提供了强大支持。可以…

ubuntu22.04 修改内核源码教程

1. 确认当前内核版本 uname -a 2. 去ubuntu官网下载对应版本内核源码 6.5.0-28.29 : linux package : Ubuntu (launchpad.net) 3. 准备编译环境 sudo apt-get install libncurses5-dev libssl-dev build-essential openssl flex bison libelf-dev tar -xzvf linux_6.5.…

【VS+QT】visual studio 2022配置和搭建QT

一、下载QT 可以去QT官网下载:https://www.qt.io/product/development-tools。 直接安装。 二、安装qt插件 打开visual studio 2022&#xff0c;选择菜单栏中扩展->管理扩展 ,然后直接在vs插件市场搜索Qt Visual Studio Tools就行。 安装的时候根据提示&#xff0c;关闭…

动态规划|714.买卖股票的最佳时机含手续费

力扣题目链接 class Solution { public:int maxProfit(vector<int>& prices, int fee) {int n prices.size();vector<vector<int>> dp(n, vector<int>(2, 0));dp[0][0] - prices[0]; // 持股票for (int i 1; i < n; i) {dp[i][0] max(dp[i …

java案例-服务端与客户端(传输对象)

需求 代码 SysUser 用户类Operation 操作类Client 客户端Server 服务端ServerReaderThread 服务端线程类 SysUser 用户类 需要实现Serializable 方便序列化&#xff0c;传输对象 public class SysUser implements Serializable {private String username;private String passwo…

Swift - 枚举

文章目录 Swift - 枚举1. 枚举的基本用法2. 关联值&#xff08;Associated Values&#xff09;3. 关联值举例4. 原始值5. 隐式原始值&#xff08;Implicitly Assigned Raw Values&#xff09;6. 递归枚举&#xff08;Recursive Enumeration&#xff09;7. MemoryLayout Swift -…

解锁无限创意—MidjourneyAI绘画系统源码 支持AI智能会话+分销功能 对接ChatGPT+Midjourney接口 集成国内外众多AI大模型

在数字化浪潮汹涌的时代&#xff0c;人工智能已经成为推动社会进步的重要力量。而在艺术创作领域&#xff0c;MidjourneyAI绘画系统正以其强大的源码支持、智能会话功能、以及独特的分销模式&#xff0c;引领着智能艺术的新潮流。 分享一款MidjourneyAI绘画系统的源码&#xf…

leetcode多个测试用例之间相互影响导致提交失败

背景 在做一道easy题&#xff0c;二叉树的中序遍历&#xff0c;我提交的代码如下 from typing import (Optional,List )# Definition for a binary tree node. class TreeNode:def __init__(self, val0, leftNone, rightNone):self.val valself.left leftself.right right…

基础动态规划 - 过河卒

过河卒 兵从A点走到B点的所有路径方案&#xff0c;且不能经过 “马能吃棋子”的格子。 如果没有马&#xff0c;那么这道题就是一个简单的从A点走到B点的所有路径情况的简单动态规划。 状态转移方程为 dp[i,j] dp[i - 1,j] dp[i,j - 1]。 但如果加上了马这个棋子&#xff0…

一份报告实现两电平逆变、三电平逆变、三相整流、光伏并网simulink仿真

一份报告实现两电平逆变、三电平逆变、三相整流、光伏并网simulink仿真。逆变、整流与光伏的全家桶系列&#xff0c;适合小白使用。 模型获取链接&#xff1a;一份报告实现两电平逆变、三电平逆变、三相整流、光伏并网simulink仿真

llama3本地部署

目录 II.下载 II.验证ollama安装 II.安装llama3 和启动 II.命令行调用 II.api调用 II.参考文献 II.下载 https://ollama.com/download/windows OllamaSetup.exe https://github.com/meta-llama/llama3 II.验证ollama安装 cmd ollama II.安装llama3 和启动 ollama run …

LeetCode 2385.感染二叉树需要的总时间:两次搜索(深搜 + 广搜)

【LetMeFly】2385.感染二叉树需要的总时间&#xff1a;两次搜索&#xff08;深搜 广搜&#xff09; 力扣题目链接&#xff1a;https://leetcode.cn/problems/amount-of-time-for-binary-tree-to-be-infected/ 给你一棵二叉树的根节点 root &#xff0c;二叉树中节点的值 互不…

永磁同步电机SMO负载转矩观测matlab模型。

永磁同步电机SMO负载转矩观测matlab模型。 负载转矩的有效识别是提高伺服驱动系统抗负载扰动性能的关键之一。现在的传统结构的LTID滑模观测器存在频率抖动大&#xff0c;估计精度差的缺点&#xff0c;限制了其在高性能伺服系统中的应用。 本模型推导分析了传统LTID滑模观测器…

图片浏览工具-Honeyview

一、软件特点 轻量而快速 可以显示包括 GPS 信息在内的 JPEG 格式的 EXIF 信息 对图像格式进行批量转换和调整大小 支持显示 GIF 和 WebP 动图 无需解压即可直接查看压缩包中的图像 二、支持的格式 图像格式: BMP, JPG, GIF, PNG, PSD, DDS, JXR, WebP, J2K, JP2, TGA, TIFF, …

电商系统-农产品销售网站

一、今天给大家介绍一个VUESPRINGBOOT实现的农产品销售网站系统。包含商品海报轮播、商品分类展示、商品排行展示、推荐商品展示、购物车、订单、收藏、个人中心、收货地址维护、充值、如果是认证的商家还可以接入支付宝支付系统。下面来看下界面UI吧。 二、商品展示 三、购物车…

239.滑动窗口最大值

经典的单调队列的题目,不刷必后悔 思路解析: 显然我们可以可以写一个简单的O(nk)的算法,但是会超时.考虑到本题是需要维护一个有限制的最大值,我们使用单调队列这个数据结构优化这个过程. 单调队列里面存储元素的下标,队头是当前的窗口最大值,按照递减排列,显然从队头到队尾的…

聊聊Flink:Docker搭建Flink

一、准备工作 查看下Docker和Docker Compose版本&#xff0c;确保你安装了这些软件。 在 Flink 官网上下载 Flink 的 Docker 镜像。您可以使用以下命令从 Docker Hub 中下载&#xff1a; docker pull flink:1.18.0-scala_2.12 此命令将下载 Flink 1.18.0 版本的 Docker 镜像…

诡异的scp导致文件被清空问题

scp简介 scp 是 Linux 系统下基于 SSH 登陆进行安全的远程文件拷贝命令。它允许你在不同的 Linux 机器之间复制文件或目录。 使用 scp 命令的基本格式如下&#xff1a; 从本地复制到远程&#xff1a; scp [options] source_file userremote:destination_folder 从远程复制…

一文读懂Partisia Blockchain 的互操作方案:Oracle 服务框架

Partisia Blockchain 是一个以 MPC 技术为特点的创新隐私公链&#xff0c;其通过将 MPC 技术方案引入到区块链系统中&#xff0c;并以零知识证明&#xff08;ZK&#xff09;技术和多方计算&#xff08;MPC&#xff09;等方案为基础&#xff0c;共同保障在不影响网络完整性和安全…