嵌入式学习记录——线程

线程基本概念:

         线程:线程是一个轻量级的进程,位于进程空间内部,一个进程中可以创建多个线程

1.线程创建:

          线程独占栈空间,文本段、数据段和堆区与进程共享

2.线程调度:

                与进程调度是一样的
                宏观并行,微观串行

3.线程消亡:

与进程消亡是一样的

4.进程和线程的区别:

                进程是操作系统资源分配的最小单元
                线程是CPU任务调度的最小单元

5.多进程和多线程的优缺点:

效率:多线程 > 多进程 

                 多线程只需在同一进程空间内切换
                 多进程需要在不同的空间中切换

通信:多线程 > 有进程

                 线程共享全局变量,可以通过全局变量实现数据通信
                 进程空间是独立的,没有共享空间,通信实现比较复杂

安全:多进程 > 多线程

                一个进程异常不会影响其余进程空间
                一个线程异常结束会导致进程异常结束,进程异常结束,该进程内所有线程任务均无法向下执行

6.线程相关的函数接口:

        创建: fork      pthread_create 
        退出: exit      pthread_exit 
        回收: wait      pthread_join    

1.pthread_create

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

功能:
            在该进程中创建一个新的线程

 参数:
            thread:存放线程ID空间首地址
            attr:线程属性空间首地址
            start_routine:线程要执行的函数的入口
            arg:给线程函数的参数

返回值:
            成功返回0 
            失败返回错误码

编译时加 -lpthread选项  

2.pthread_self

 pthread_t pthread_self(void);

功能:
            获得调用该函数线程的ID  

3.pthread_exit 

  void pthread_exit(void *retval);

 功能:
            让调用该函数的线程任务结束

   参数:
            retval:线程结束的值

  4.pthread_join 

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

 功能:
            回收线程空间

  参数:
            thread:线程的ID号
            retval:存放线程结束状态空间的首地址

          返回值:
            成功返回0 
            失败返回错误码

7.线程分离属性:

         线程结束后,自动回收线程空间

pthread_attr_init

            int pthread_attr_init(pthread_attr_t *attr);

功能:
      线程属性初始化

pthread_attr_destroy
            int pthread_attr_destroy(pthread_attr_t *attr);

功能:
      线程属性销毁

pthread_attr_setdetachstate 
            int pthread_attr_setdetachstate(pthread_attr_t *attr, int detachstate);

功能:
      设置分离属性 

PTHREAD_CREATE_DETACHED   分离属性
PTHREAD_CREATE_JOINABLE   加入属性(默认)

8.线程互斥:

1.互斥锁:防止资源竞争

 2.函数接口:

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

功能:
        互斥锁初始化

参数:
        mutex:互斥锁空间首地址
        attr:互斥锁的属性(默认为NULL)

返回值:
        成功返回0 
        失败返回错误码 

pthread_mutex_destroy:
      int pthread_mutex_destroy(pthread_mutex_t *mutex);

功能:
        互斥锁销毁

参数:
        mutex:互斥锁空间首地址

返回值:
        成功返回0 
        失败返回错误码 

pthread_mutex_lock:
      int pthread_mutex_lock(pthread_mutex_t *mutex);

功能:
        上锁

pthread_mutex_unlock:
      int pthread_mutex_unlock(pthread_mutex_t *mutex);

功能: 
        解锁

3.临界资源、临界区:

      加锁解锁中间的代码称为临界资源、临界区
      同一时刻临界资源不能同时执行,只能执行其中一个临界资源代码

4.原子操作:

      CPU最小的一次不能被任务调度打断的操作称为原子操作

5.互斥锁只能解决资源竞争的问题,无法同步代码(没有先后执行的顺序关系)

6.死锁:

    多线程操作互斥锁,导致多个线程均无法向下执行的状态称为死锁状态简称为死锁

    死锁产生的四个必要条件:
      1.互斥条件
      2.不可剥夺条件
      3.请求保持
      4.循环等待

避免产生死锁:
      1.pthread_mutex_trylock 替代 pthread_mutex_lock
      2.加锁顺序保持一致

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

StreamTask数据流:StreamTask能力概述、Flink处理网络数据逻辑

文章目录 一. StreamTask核心组件与能力二. OneInputStreamTask接入网络数据并处理三. 处理数据1. StreamElement类别2. 业务数据处理逻辑 四. 小结 先来看数据是如何经过网络写入下游Task节点并通过算子进行处理的,这里以OneInputStreamTask为例进行说明。 一. St…

go 程序被意外kill后出现僵尸进程解决方案

go 管理自身子进程(防止僵尸进程出现) 写这篇文章是因为最近有同事竟然会知道异步启动子进程,不会关闭,最后导致导致僵尸进程出现,而且由于子进程会随着业务的使用越开越多,主进程一旦被kill掉就会不得不手动一个一个kill。 大概…

AWS虚拟机迁移到Azure上的实战操作

将一台虚拟机从AWS迁移到Azure涉及几个关键步骤,包括准备工作、虚拟机的备份与导出、格式转换、上传到Azure以及在Azure上创建新的虚拟机实例。以下是详细的步骤和示例: 一、 准备阶段 Azure和AWS的免费账户请参考下面的链接: 想学习云计算么?教你如何免费白嫖微软和AWS…

004-CSS-左右经典布局

左右经典布局 方案一:弹性盒子布局方案二:绝对定位 padding方案三:绝对定位 margin方案四:行内块布局 calc方案五:浮动 BFC 方案一:弹性盒子布局 💡 Tips:左侧子盒子宽度固定&a…

Python并发编程:协程-greenlet模块

一 greenlet模块 如果我们在单个线程内有20个任务,要想实现在多个任务之间切换,使用yield生成器的方式过于麻烦(需要先得到初始化一次的生成器,然后再调用send。。。非常麻烦),而使用greenlet模块可以非常简…

鸿蒙Harmony应用开发—ArkTS声明式开发(通用属性:多态样式)

设置组件不同状态下的样式。 说明: 从API Version 8开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。 从API Version 11开始支持另一种写法attributeModifier,可根据开发者需要动态设置属性。 stateStyles stateStyl…

16:00面试,16:06就出来了,问的问题过于变态了。。。

从小厂出来,没想到在另一家公司又寄了。 到这家公司开始上班,加班是每天必不可少的,看在钱给的比较多的份上,就不太计较了。没想到2月一纸通知,所有人不准加班,加班费不仅没有了,薪资还要降40%…

微信报修小程序源码

源码获取方式: 1、搜一搜 万能工具箱合集 然后点击资料库,即可获取资源 一、先看Demo(已更新至4.0.0) 想看界面图片的,辛苦你爬一下楼,点击下方查看资源,进入官方demo 二、功能介绍 1、当前版…

什么是AJAX?它的运用场景有哪些?

文章目录 前言一、什么是AJAX二、AJAX原理是什么三、为什么需要AJAX四、AJAX的使用五、AJAX的应用场景 前言 AJAX 即 Asynchronous Javascript And XML(异步JavaScript和XML),是指一种创建交互式网页应用的网页开发技术。 AJAX 是一种用于创…

LLM(十一)| Claude 3:Anthropic发布最新超越GPT-4大模型

2024年3月4日,Anthropic发布最新多模态大模型:Claude 3系列,共有Haiku、Sonnet和Opus三个版本。 Opus在研究生水平专家推理、基础数学、本科水平专家知识、代码等10个维度,超过OpenAI的GPT-4。 Haiku模型更注重效率,能…

正则表达式判断IP地址(python)

正则表达式判断IP地址(python) 分情况: 1位数:0 | 1-9 2位数:[1-9][0-9] 3位数: 1开头:1[0-9]{2} 2开头:2[0-4][0-9] | 25[0-5] 1、2位数:0 | [1-9][0-9]? 3位数&#x…

稀碎从零算法笔记Day7-LeetCode:罗马数字转整数

题型:字符串转化、找规律 链接:13. 罗马数字转整数 - 力扣(LeetCode) 来源:LeetCode 题目描述 给定一个数组 prices ,它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格。 你只能选择 某一天 …

SpringCloud远程调用Feign

一,什么是Feign Feign是一个声明式的http客户端底层还是基于HTTP实现,是SpringCloud的核心组件之一,实现了微服务之间的远程调用。 二,Feign的使用步骤 1,引入依赖 引入Spring Cloud start Feign的依赖 &#xff0c…

关于我使用numpy.random.choice()遇到坑这件事

做仿真时经常使用到随机数,下面是一个场景:使用np.random.choice([0,1],p[0.5,0.5],size1)去进行随机的二选一,假设需要随机选择1000次,为了保证结果的稳健性,对前述过程重复50次,为了保证可复现性&#xf…

collection及迭代遍历

Collection是单列集合的祖宗接口,它的功能是全部单列集合都可以继承使用的。 package myCollection;import java.util.ArrayList; import java.util.Collection;public class A01CollectionDemo1 {public static void main(String[] args) {//collection是一个接口…

《PyTorch深度学习实践》第十一讲卷积神经网络进阶

一、 1、卷积核超参数选择困难,自动找到卷积的最佳组合。 2、1x1卷积核,不同通道的信息融合。使用1x1卷积核虽然参数量增加了,但是能够显著的降低计算量(operations) 3、Inception Moudel由4个分支组成,要分清哪些是在Init里定义…

基于springboot+vue的精简博客系统

博主主页:猫头鹰源码 博主简介:Java领域优质创作者、CSDN博客专家、阿里云专家博主、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战,欢迎高校老师\讲师\同行交流合作 ​主要内容:毕业设计(Javaweb项目|小程序|Pyt…

Nginx配置文件的整体结构

一、Nginx配置文件的整体结构 从图中可以看出主要包含以下几大部分内容: 1. 全局块 该部分配置主要影响Nginx全局,通常包括下面几个部分: 配置运行Nginx服务器用户(组) worker process数 Nginx进程PID存放路径 错误…

Linux 防火墙 操作命令【实用】

防火墙操作: 描述命令查看防火墙状态systemctl status firewalld、firewall-cmd --state暂时关闭防火墙systemctl stop firewalld永久关闭防火墙systemctl disable firewalld开启防火墙systemctl start firewalld开放指定端口firewall-cmd --zonepublic --add-port…

Java集合5-HashSet

HashSet&#xff1a;基于哈希表实现的集合&#xff0c;用于存储不重复的元素。 HashSet<String> set new HashSet<>(); set.add("Item 1"); set.add("Item 2");HashSet 是一个不允许存储重复元素的集合&#xff0c;它的实现比较简单&#xf…