Linux线程

2023-10-27

1、进程线程区别

1.进程占内存,比如父子进程copy内存空间
线程共享内存空间
2.线程切换和创建速度比进程快
进程开销大约是线程的30倍
3.线程因为共享内存,所以通信快

2、线程(创建退出等待)

1.API

int pthread_create(pthread_t *thread, const pthread_attr_t *attr,void *(*start_routine) (void *), void *arg);

创建
返回值:成功0失败-1
参数1:pthread_t型指针t1
参数2:线程属性,NULL
参数3:函数指针
参数4:无类型数据
例:
函数void* func1(void*arg)
输出主函数传过来的值,*((int*)arg)
set=pthread_create(&t1,NULL,func1,(void*)&param);

void pthread_exit(void *retval);

退出
参数:无类型指针,int char都可以,但线程函数里定义要static,保证内存不释放,主函数才能打印。
例:
static int set=10
pthread_exit((void*)&set)

int pthread_join(pthread_t thread, void **retval);

等待,主函数阻塞一直等待线程退出
参数1:线程t1,创建线程的参数1
参数2:线程退出返回的值,二级指针
例:
int *pret=NULL
pthread_join(t1,(void**)&pret)
输出直接输出pret地址内容

pthread_t pthread_self(void);

返回线程id
返回值:长整型
例:
主线程和新线程都有id
%ld输出
(unsigned long)pthread_self()

int pthread_equal(pthread_t t1, pthread_t t2);

id比较,相等返回非0,否则0
2.例:
创建线程
编写线程函数,输出主函数的值和线程id,退出返回一个数据
主函数,输出id,等待线程,输出线程退出的数
注:编译加-lpthread

#include <stdio.h>
#include <stdlib.h>
#include <pthread.h>

void *fun1(void *arg)
{
        static char *ptr = "wei";
        printf("t1:main=%d\n",*((int *)arg));
        printf("t1:id=%ld\n",(unsigned long)pthread_self());
        pthread_exit((void *)ptr);
}

int main()
{
        pthread_t t1;
        int arg = 100;
        char *a = NULL;
        if(pthread_create(&t1, NULL, fun1, (void *)&arg) == 0){
                printf("found thread succeed\n");
        }

        printf("main:id=%ld\n",(unsigned long)pthread_self());

        pthread_join(t1, (void **)&a);
        printf("main:t1 exit,%s\n",(char*)a);
        return 0;
}

/*
found thread succeed
t1:main=100
t1:id=140084299699968
main:id=140084308203328
main:t1 exit,wei
*/

3、互斥量,锁

1.互斥量本质上是锁
加锁,解锁在线程开头结尾,可以保证线程在执行完之前不被打断。(主函数可以打断)
2.API

int pthread_mutex_init(pthread_mutex_t *restrict mutex,const pthread_mutexattr_t *restrict attr)

互斥量创建(锁)
参数1:全局变量,指针
参数2:默认属性互斥量,NULL

int pthread_mutex_destroy(pthread_mutex_t *mutex)

销毁锁
参数:创建锁时的全局变量

int pthread_mutex_lock(pthread_mutex_t *mutex)

加锁
参数:全局变量指针

int pthread_mutex_unlock(pthread_mutex_t *mutex)

解锁
参数:全局变量指针
3.线程的共享内存
线程改变全局变量
4.例:
全局变量data和锁变量
创建锁,创建2个线程
2线程函数
1: 加锁,循环data++,sleep延时1s,if3解锁退出线程
2:死循环输出data,加锁data++,解锁,延时1s
主函数
打印data
等待线程
销毁锁
注:线程2加锁是因为锁被线程1拿了,没有锁拿就会卡在那里。

#include <stdio.h>
#include <stdlib.h>
#include <pthread.h>
#include <unistd.h>

int data = 0;
pthread_mutex_t nutex;

void *fun1(void *arg)
{
        printf("t1:id=%ld\n",(unsigned long)pthread_self());
        pthread_mutex_lock(&nutex);
        while(1){
                data++;
                printf("t1:data=%d\n",data);
                if(data == 3){
                        printf("t1 quit =============================\n");
                        pthread_mutex_unlock(&nutex);
                        pthread_exit(NULL);
                }
                sleep(1);
        }
}

void *fun2(void *arg)
{
        printf("t2:id=%ld\n",(unsigned long)pthread_self());
        while(1){
                pthread_mutex_lock(&nutex);
                data++;
                pthread_mutex_unlock(&nutex);
                printf("t2:data=%d\n",data);
                sleep(1);
        }
        pthread_exit(NULL);
}

int main()
{
        pthread_t t1;
        pthread_t t2;
        int arg = 100;
        pthread_mutex_init(&nutex, NULL);
        if(pthread_create(&t1, NULL, fun1, (void *)&arg) == 0){
                printf("found thread succeed\n");
        }

        if(pthread_create(&t2, NULL, fun2, (void *)&arg) == 0){
                printf("found thread succeed\n");
        }
        printf("main:id=%ld\n",(unsigned long)pthread_self());
        while(1){
                printf("main:%d\n",data);
                sleep(1);
        }

        pthread_join(t1,NULL);
        pthread_join(t2,NULL);
        pthread_mutex_destroy(&nutex);
        return 0;
}
/*
found thread succeed
t1:id=140562014590720
t1:data=1
found thread succeed
main:id=140562023094080
main:1
t2:id=140562006198016
main:1
t1:data=2
t1:data=3
t1 quit =============================
main:2
t2:data=4
main:4
t2:data=5
t2:data=6
main:6
*/

3、什么是死锁

2个线程有时会造成死锁,2个锁
一个线程拿到锁1,要拿锁2
另一个拿到锁2,要拿锁1
造成2个线程都不能继续运行下去
在这里插入图片描述

4、条件

1.一个线程等待触发条件。
2.API

int pthread_cond_init

创建

pthread_cond_destroy

销毁

int pthread_cond_wait(pthread_cond_t *cond,pthread_mutex_t *mutex)

等待
参数1:条件
参数2:锁

pthread_cond_signal

触发
参数:条件&cond

pthread_cond_broadcast

广播
3.例:
2个线程,锁,条件初始化
线程1等待条件
线程2加锁data++,触发条件
线程1执行

#include <stdio.h>
#include <stdlib.h>
#include <pthread.h>
#include <unistd.h>

int data = 0;
pthread_cond_t cond = PTHREAD_COND_INITIALIZER;
pthread_mutex_t nutex = PTHREAD_MUTEX_INITIALIZER;


void *fun1(void *arg)
{
        while(1){
                pthread_cond_wait(&cond, &nutex);
                printf("t1:%d\n",data);
                data = 0;
        }
}

void *fun2(void *arg)
{
        while(1){
                pthread_mutex_lock(&nutex);
                data++;
                pthread_mutex_unlock(&nutex);
                printf("t2:data=%d\n",data);
                if(data == 3){
                        pthread_cond_signal(&cond);
                }
                sleep(1);
        }
        pthread_exit(NULL);
}

int main()
{
        pthread_t t1;
        pthread_t t2;
        pthread_mutex_init(&nutex, NULL);
        pthread_create(&t1,NULL,fun1,NULL);
        pthread_create(&t2,NULL,fun2,NULL);

        pthread_join(t1,NULL);
        pthread_join(t2,NULL);
        pthread_cond_destroy(&cond);
        pthread_mutex_destroy(&nutex);
        return 0;
}
/*
t2:data=1
t2:data=2
t2:data=3
t1:3
t2:data=1
t2:data=2
t2:data=3
t1:3
t2:data=1
t2:data=2
t2:data=3
t1:3
*/

5、线程初始化宏

动态初始化

pthread_cond_init(&cond, NULL);

静态初始化

pthread_cond_t cond=PTHREAD_COND_INITIALIZER

6、生产者消费者

数据缓冲期访问

师承上官可编程 —— 陈立臣

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Linux线程 的相关文章

  • 在 .gitconfig 中隐藏 GitHub 令牌

    我想将所有点文件存储在 GitHub 上 包括 gitconfig 这需要我将 GitHub 令牌隐藏在 gitconfig 中 为此 我有一个 gitconfig hidden token 文件 这是我打算编辑并放在隐藏令牌的 git 下
  • 如何使用 Cloud Init 挂载未格式化的 EBS 卷

    Context 我正在使用https wiki jenkins io display JENKINS Amazon EC2 Plugin https wiki jenkins io display JENKINS Amazon EC2 Pl
  • 在centos中安装sqlite3 dev和其他包

    我正在尝试使用 cpanel 在 centos 机器上安装 sqlite dev 和其他库 以便能够编译应用程序 我对 debian 比 centos 更熟悉 我知道我需要的库是 libsqlite3 dev libkrb5 dev lib
  • 如何在linux中以编程方式获取dir的大小?

    我想通过 C 程序获取 linux 中特定目录的确切大小 我尝试使用 statfs path struct statfs 但它没有给出确切的大小 我也尝试过 stat 但它返回任何目录的大小为 4096 请建议我如何获取 dir 的确切大小
  • 无需超级用户即可在 Linux 中打开 RAW 套接字

    我必须编写一个在 Linux 上运行的 ping 函数 语言是 C 所以 C 也可以 在网上搜索并查看源代码ping命令 事实证明我应该创建一个原始套接字 icmp sock socket AF INET SOCK RAW IPPROTO
  • 添加文件时运行 shell 命令

    我的 Linux 机器上有一个名为 images 的文件夹 该文件夹连接到一个网站 该网站的管理员可以向该网站添加图片 但是 当添加图片时 我想要一个命令来运行调整目录中所有图片的大小 简而言之 我想知道当新文件添加到特定位置时如何使服务器
  • 在 Mono 上运行 .Net MVC5 应用程序

    我正在 Windows 上的 Visual Studio 2013 中开发 Net 4 5 1 MVC5 应用程序 现在我想知道 是否可以在Linux Ubuntu 12 04 上运行这个应用程序 可以使用OWIN吗 Owin 可以自托管运
  • .net-core:ILDASM / ILASM 的等效项

    net core 是否有相当于 ILDASM ILASM 的功能 具体来说 我正在寻找在 Linux 上运行的东西 因此为什么是 net core ildasm 和 ilasm 工具都是使用此存储库中的 CoreCLR 构建的 https
  • 如何使用waf构建共享库?

    我想使用构建一个共享库waf http code google com p waf 因为它看起来比 GNU 自动工具更容易 更简洁 到目前为止 我实际上有几个与我开始编写的 wscript 有关的问题 VERSION 0 0 1 APPNA
  • 与 pthread 的进程间互斥

    我想使用一个互斥体 它将用于同步对两个不同进程共享的内存中驻留的某些变量的访问 我怎样才能做到这一点 执行该操作的代码示例将非常感激 以下示例演示了 Pthread 进程间互斥体的创建 使用和销毁 将示例推广到多个进程作为读者的练习 inc
  • C修改printf()输出到文件

    有没有办法修改printf为了将字符串输出到文件而不是控制台 我尝试在互联网上查找一些内容 发现了类似的电话dup dup2 and fflush这可能与此有关 EDIT 也许我不清楚 问题是这是C考试问题 问题如下 解释一个通常将字符串输
  • Apache 访问 Linux 中的 NTFS 链接文件夹

    在 Debian jessie 中使用 Apache2 PHP 当我想在 Apache 的文档文件夹 var www 中创建一个新的小节时 我只需创建一个指向我的 php 文件所在的外部文件夹的链接 然后只需更改该文件夹的所有者和权限文件夹
  • 这种文件锁定方法可以接受吗?

    我们有 10 个 Linux 机器 每周必须运行 100 个不同的任务 这些计算机主要在我们晚上在家时执行这些任务 我的一位同事正在开发一个项目 通过使用 Python 自动启动任务来优化运行时间 他的程序将读取任务列表 抓取一个打开的任务
  • cdc_acm:无法设置 dtr/rts - 无法与 USB cdc 设备通信

    我试图使用 pic24fj128gb206 枚举 usb cdc 设备 设备似乎已正确枚举 但是当我将设备连接到 Linux PC 时 我从内核收到以下警告消息 cdc acm 1 8 1 6 7 1 0 failed to set dtr
  • ansible unarchive 模块如何查找 tar 二进制文件?

    我正在尝试执行一个 ansible 剧本 该剧本的任务是利用unarchive模块 因为我是在 OSX 上执行此操作 所以我需要使用它gnu tar 而不是bsd tar通常与 OSX 一起提供 因为BSD tar 不受官方支持 https
  • 为什么 XRecordDisableContext() 不起作用?

    void Callback XPointer XRecordInterceptData pRecord std cout lt lt my logs n int main if auto const pDisplay XOpenDispla
  • 如何在文件中搜索多行模式?

    我需要找到包含特定字符串模式的所有文件 我想到的第一个解决方案是使用find管道与xargs grep find iname py xargs grep e YOUR PATTERN 但是 如果我需要查找跨越多行的模式 我就会陷入困境 因为
  • 为 OpenWrt 编写和编译程序

    我有一个在 OpenWRT 下运行的具有 MIPS 架构的嵌入式设备 系统类型 MediaTek MT7628AN ver 1 eco 2机器 WRTnode2P 处理器 0CPU型号 MIPS 24KEc V5 5 我想通过我的电脑 ub
  • 如何找到进程启动时使用的原始用户名?

    有一个 perl 脚本需要以 root 身份运行 但我们必须确保运行该脚本的用户最初没有以用户 foo 身份登录 因为它将在脚本运行期间被删除 那么 我如何查明自登录以来可能已多次起诉的用户是否在该链中的任何时间都没有模拟过 foo 我发现
  • 从另一个 python 脚本获取返回信息

    我在 Linux 上 我有一个 python 脚本 我想从另一个 python 脚本调用它 我不想将其作为模块导入 为了一层安全性 现在为了学术练习 因为我想弄清楚这一点 我实际上想让一个脚本使用 os system 或另一个类似的函数 并

随机推荐

  • 让别人写一个python爬虫程序大概要多少钱?

    前言 目前 对于程序代做来说没有统一标准 不像论文那样可以按照字数来定价 根据行业经验 总结出了一个python代写的参考价格 一般来说如果想写本科的python作业 一般是500起 硕士作业按照项目算的话 一般是1500起 影响pytho
  • JS的作用域问题

    一 块级作用域 在 JavaScript 中 作用域为可访问变量 对象 函数的集合 js没有块级作用域 你可以自己闭包或其他方法实现 只有函数级作用域 函数外面的变量函数里面可以找到 函数里面的变量外面找不到 var a 10 functi
  • Nginx 七层和四层负载均衡——筑梦之路

    七层负载均衡示例配置 worker processes 2 events worker connections 1024 7层http负载 http include mime types default type application o
  • Python全栈开发【基础-07】与用户交互

    专栏介绍 本专栏为Python全栈开发系列文章 技术包括Python基础 函数 文件 面向对象 网络编程 并发编程 MySQL数据库 HTML JavaScript CSS JQuery bootstrap WSGI Django Flas
  • C++ list, vector, map, set 区别与用法比较

    一 list和vector List封装了链表 Vector封装了数组 list和vector得最主要的区别在于vector使用连续内存存储的 他支持 运算符 而list是以链表形式实现的 不支持 Vector对于随机访问的速度很快 但是对
  • 华为OD机试真题 Java 实现【组合出合法最小数】【2023Q1 200分】,附详细解题思路

    一 题目描述 给一个数组 数组里面都是代表非负整数的字符串 将数组里所有的数值排列组合拼接起来组成一个数字 输出拼接成的最小的数字 二 输入描述 一个数组 数组不为空 数组里面都是代表非负整数的字符串 可以是0开头 例如 13 045 09
  • Tkinter模拟发送邮箱验证码并在指定时间后验证码过期

    先上两张图 再解释 运行原理 程序运行后 输入要接收验证码的邮箱地址 点击 发送 后 控制台打印输出得到的验证码并发送到邮箱里 过了15秒以后 验证码再次刷新 并打印输出 这样就实现了动态过期 原理就是到某个时间点我再刷新一遍生成验证码函数
  • Hadoop命令大全

    目录 基本语法 一 上传 二 下载 三 其他增删改查操作 3 1 增 3 2 删 3 3 改 3 4 查 基本语法 hadoop fs 和 hdfs dfs hadoop fs和hdfs dfs命令等效 hdfs dfs 只能操作HDFS文
  • FISCO-BCOS学习——区块链浏览器搭建

    注意 本系列文章遇到的问题都可以参考查找 官方文档 或 本系列问题总结 FISCO BCOS 及 WeBase 问题记录 FISCO BCOS 官方文档 WeBase 官方文档 FISCO BCOS区块链浏览器搭建 前提条件 环境 版本 J
  • STM32的HAL库SPI操作(master 模式)-根据时序图配置SPI

    SPI相关基础知识 SPI基本概念请自行百度 参考 百度百科SPI简介 我们讲重点和要注意的地方 master模式下要关注的地方 接线一一对应 也就是说主控的MISO MOSI SCLK CSn 分别和设备的MISO MOSI SCLK C
  • 数据清洗之朝阳医院2018年销售数据分析

    朝阳医院2018年销售数据分析 所用到的数据提取地址 gt 戳这里下载 或私我 过程 整体代码 导入库 import pandas as pd import numpy as np import matplotlib pyplot as p
  • STM32F103ZET6---【硬件篇】定时器

    STM32的TIM1 TIM8为高级定时器 TIM2 TIM3 TIM4 TIM5为通用定时器 TIM6 TIM7为基本定时器 各个定时器引脚如下 TIM1和TIM8定时器的功能包括 16位向上 向下 向上 下自动装载计数器 16位可编程
  • RealBasicVSR训练(三)用自己的数据集训练

    由于上一篇中的方法只能用1个gpu训练 故重新采取之前的训练方法 第一步 RealBasicVSR master mim train mmedit configs realbasicvsr wogan c64b20 2x30x8 lr1e
  • 2023最新SSM计算机毕业设计选题大全(附源码+LW)之java基于HTML5的流浪动物领养平台yww0b

    很多大学生 成考 自考 全日制本科 大专的学生都因为毕设没有完成而延时毕业的情况 现在分享给大家选题 下面有2023年做的选题 最后面有选题 源码 论文下载网站给大家学习 如今计算机技术的飞速发展 大约三 四年前 软件工程是市场的热门领域
  • 电荷泵电路(Charge Pump)用于升压的解析

    升压的电荷泵电路 Charge Pump 也称为开关电容转换器 Switched Capacitor Converter 老粉丝都知道 公众号很久之前就发布了一篇阐述电感 电容 二极管构成的BOOST升压方案的文章 那为什么还要讨论电荷泵方
  • 小谈类机制相关

    小谈类机制相关 本文主要涉及类相关的一些常见面试问题 以及相关特性 包括 this 指针 拷贝构造函数相关以及类机制 一 this指针 编译器在编译普通成员函数时 会隐式的分配一个形参指针 即this指针 并且当实例化对象调用该成员函数时
  • Python 时间比较大小 并从dataframe中提取满足时间条件的量

    之前一直用时间数据相互加减然后判断是否大于0来判断大小 但是发现时间数据居然可以直接比较 Python 时间比较大小 可以直接用比较运算符 gt lt 输出bool类型 True False 先定义一个包含时间数据的dataframe t1
  • python None理解与应用

    官方文档 None是NoneType类型的唯一值 所以None既不是空列表 也不是空字符串 None通常用来代表空值 或者表示函数默认没有入参 如下图 None不能被赋值 否则会报错 它跟True False一样也是built in con
  • android Intent 全面点的介绍

    第一种方式 用action来跳转 1 使用Action跳转 如果有一个程序的AndroidManifest xml中的某一个Activity的IntentFilter段中 定义了包含了相同的Action那么这个Intent就与这个目标Act
  • Linux线程

    目录 1 进程线程区别 2 线程 创建退出等待 3 互斥量 锁 3 什么是死锁 4 条件 5 线程初始化宏 6 生产者消费者 1 进程线程区别 1 进程占内存 比如父子进程copy内存空间 线程共享内存空间 2 线程切换和创建速度比进程快