【linux 多线程并发】多线程的控制,挂起线程暂停运行,直到唤醒线程,取消线程运行,可以设置合适的取消点属性避免不安全点被中止
线程运行控制
专栏内容:
参天引擎内核架构
本专栏一起来聊聊参天引擎内核架构,以及如何实现多机的数据库节点的多读多写,与传统主备,MPP的区别,技术难点的分析,数据元数据同步,多主节点的情况下对故障容灾的支持。手写数据库toadb
本专栏主要介绍如何从零开发,开发的步骤,以及开发过程中的涉及的原理,遇到的问题等,让大家能跟上并且可以一起开发,让每个需要的人成为参与者。
本专栏会定期更新,对应的代码也会定期更新,每个阶段的代码会打上tag,方便阶段学习。
开源贡献:
- toadb开源库
个人主页:我的主页
管理社区:开源数据库
座右铭:天行健,君子以自强不息;地势坤,君子以厚德载物.
文章目录
- 线程运行控制
- 前言
- 概述
- 线程控制方法概览
- 暂停线程
- 唤醒线程
- 线程取消
- 线程取消 API
- 线程取消流程
- 线程取消的原理
- 线程取消点
- 取消点属性
- 属性设置API
- 参数说明
- 总结
- 结尾
前言
现代的CPU都是多core处理器,而且在intel处理器中每个core又可以多个processor,形成了多任务并行处理的硬件架构,在服务器端的处理器上架构又有一些不同,传统的采用SMP,也就是对称的多任务处理架构,每个任务都可以对等的访问所有内存,外设等,而如今在ARM系列CPU上,多采用NUMA架构,它将CPU核分了几个组,给每个组的CPU core分配了对应的内存和外设,CPU访问对应的内存和外设时速度最优,跨组访问时性能会降底一些。
随着硬件技术的持续发展,它们对一般应用的性能优化能力越来越强,同时对于服务器软件的开发,提出更高要求,要想达到极高的并发和性能,就需要充分利用当前硬件架构的特点,对它们进行压榨。那么,我们的应用至少也是要采用多任务架构,不管是多线程还是多进程的多任务架构,才可以充分利用硬件的资源,达到高效的处理能力。
当然多任务框架的采用,不仅仅是多线程的执行,需要对多任务下带来的问题进行处理,如任务执行返回值获取,任务间数据的传递,任务执行次序的协调;当然也不是任务越多处理越快,要避免线程过多导致操作系统夯住,也要防止任务空转过快导致CPU使用率飙高。
本专栏主要介绍使用多线程与多进程模型,如何搭建多任务的应用框架,同时对多任务下的数据通信,数据同步,任务控制,以及CPU core与任务绑定等相关知识的分享,让大家在实际开发中轻松构建自已的多任务程序。
概述
在多线程并发运行过程中,总是会存在一些线程的调度管理,让一些线程暂停,唤醒线程,取消运行等,本文就来分享线程的控制方面的API,以及使用方法。
线程控制方法概览
| 方法 | API | 描述 |
|---|---|---|
| 暂停线程 | pthread_suspend_np pthread_suspend_all_np | 暂停一个指定的线程或所有线程 |
| 唤醒线程 | pthread_resume_np pthread_resume_all_np | 唤醒一个指定线程或所有线程 |
| 取消线程 | pthread_cancel | 让指定线程结束运行 |
| 创建线程取消点 | pthread_testcancel | 线程只有在取消点时才会被取消 |
| 线程取消属性设置 | pthread_setcancelstate pthread_setcanceltype | 取消属性的设置 |
暂停线程
#include <pthread_np.h>int pthread_suspend_np(pthread_t tid);
void pthread_suspend_all_np(void);
让指定线程或者其它所有线程挂起,这里调用者是不会被挂起的,如果指定挂起自己,则返回错误。
挂起的线程,只有等待唤醒通知时,才能继续运行。
唤醒线程
#include <pthread_np.h> int pthread_resume_np(pthread_t tid);
void pthread_resume_all_np(void);
唤醒指定线程,或者其它所有挂起的线程,当指定的线程没有挂起时,不产生任何动作。
当调用pthread_resume_all_np后,会扫描所有活动的线程,对于挂起的线程进行唤醒。
线程取消
线程取消,会让被取消的线程结束运行,线程退出。
线程取消 API
#include <pthread.h>
int pthread_cancel(pthread_t thread);
参数指定线程的标识符,取消指定线程,这里也包括自已;
API被调用以后,会给被取消的线程发送取消请求,取消请求是否被执行,取决于该线程是否有取消点,同时取消点属性设置为可以响应取消请求。
线程取消流程
线程处理取消请求的流程流程如下:
- 接收处理清求
- 弹出清理回调函数,并执行
- 是否有线程本地数据的销毁函数,如果有时,则执行
- 线程退出
此时,如果线程是可连接的,则pthread_join需要被调用来回收资源。
线程取消的原理
线程取消的内部是通过信号实现,发送请求,实现是发送了一个信号;这就很好理解取消点,它只是一个信号中断处理点。
线程取消点
#include <pthread.h>
void pthread_testcancel(void);
调用此API可以在程序的调用位置创建取消点,就是可以响应线程的取消;有些代码段,我们不希望被中断,必须执行或者不执行,那么就可以在此代码段的前后设置取消点。
一般线程中的取消点有以下几种:
- 调用
pthread_testcancel创建的取消点; - 让线程产生等待条件API,它们内部会有取消点,如信号量等待;
- 等待其它线程结束的调用,如
pthread_join调用; - 信号等待sigwait
- 其它一些会阻塞线程的标准库API,它们内部会有取消点,如sleep, read/write/send/recv等,在阻塞等待时,此线程仍然可以被取消运行。
取消点属性
属性设置API
#include <pthread.h>
int pthread_setcancelstate(int state, int *oldstate);
int pthread_setcanceltype(int type, int *oldtype);
参数说明
- state 取值,
- PTHREAD_CANCEL_ENABLE , 使能取消点,也就是在此调用之后,如果设置了取消点,它们就可以响应取消请求;线程默认情况下,取消点是使能的;
- PTHREAD_CANCEL_DISABLE, 禁用取消点,也就是在此调用之后,如果设置了取消点,它们不再响应取消请求; 当收到取消请求时,它们会被阻塞,直到使用取消点后。
- type 取值
- PTHREAD_CANCEL_DEFERRED, 取消请求会被延迟处理;当收到取消请求时,不会立即处理,而是在下一个取消点时处理;
- PTHREAD_CANCEL_ASYNCHRONOUS, 立即处理取消请求,当然操作系统不能保证实时性;
这两个API都是设置当前线程的取消点属性。为什么会有这两个函数呢? 因为在我们程序中不仅用到了线程库函数,还有标准C库函数,还有其它,而线程库的取消点我们可以自己设定,而其它库函数的取消点只能通过这两个函数来控制,是否需要启用。
总结
本文分享了关于线程运行、挂起、唤醒、取消运行等控制操作以及相关API,体现出并发操作的复杂性,对于挂起或取消运行要特别注意它们的时机,避免产生意想不到的结果。
本文所涉及的代码已经上传到工程hatchCode, 在multipleThreads/example_06目录下;
结尾
非常感谢大家的支持,在浏览的同时别忘了留下您宝贵的评论,如果觉得值得鼓励,请点赞,收藏,我会更加努力!
作者邮箱:study@senllang.onaliyun.com
如有错误或者疏漏欢迎指出,互相学习。
相关文章:
【linux 多线程并发】多线程的控制,挂起线程暂停运行,直到唤醒线程,取消线程运行,可以设置合适的取消点属性避免不安全点被中止
线程运行控制 专栏内容: 参天引擎内核架构 本专栏一起来聊聊参天引擎内核架构,以及如何实现多机的数据库节点的多读多写,与传统主备,MPP的区别,技术难点的分析,数据元数据同步,多主节点的情况…...
java转义字符
//转义字符的使用 public class ChangeChar{//编写一个main方法public static void main(String[] args){// \t :一个制表位,实现对齐的功能System.out.println("北京\t天津\t上海");// \n :换行符,实现换行System.out.println("jack\nsm…...
UDP服务器和客户端的创建步骤
UDP服务器的创建步骤: 一、创建用户数据报套接字(socket函数):通信域选择IPV4网络协议、套接字类型选择数据报式; int sockfd socket(AF_INET,SOCK_DGRAM,0); 二、填充服务器的网络信息结构体:1.定义网络…...
【问题记录】使用命令语句从kaggle中下载数据集
从Kaggle中下载Tusimple数据集 1.服务器环境中安装kaggle 使用命令:pip install kaggle 2.复制下载API 具体命令如下: kaggle datasets download -d manideep1108/tusimple3.配置kaggle.json文件 如果直接使用命令会报错: root:~# kagg…...
Centos 更换内核
文章目录 一、查看/更换系统内核1.1 查看当前运行环境的内核1.2 查看系统上所有可用内核1.3 切换内核方法一:通过启动菜单更换内核方法二:更换默认启动内核 二、安装内核2.1 使用ELRepo安装2.2 安装指定内核版本参考资料 一、查看/更换系统内核 1.1 查看…...
RestTemplate调用Http方法
场景:前端调用后端的接口完成设备参数的更新,后端在接口代码中需要调用设备端提供的接口来完成设备参数的更新。 RestTemplate 是用于同步client端访问 Restful 服务的一个核心类 默认使用 JDK 提供的包去建立HTTP连接 为每种 HTTP 请求都实现了相关的…...
软考笔记--操作系统-内存管理
任何程序和数据都必须占用内存空间后才能执行,因此,内存管理的好坏直接影响整个操作系统的性能。操作系统的任务之一是尽可能地方便用户使用和提高内存的利用率。同时,内存管理也是多道程序设计系统的关键支撑。内存管理的功能主要包括以下几…...
Spring Boot整合日期转换器(Converter)和拦截器(HandlerInterceptor)
添加日期转换器(Converter) public class DataConverter implements Converter<String, Date> {Overridepublic Date convert(String s) {try {SimpleDateFormat simpleDateFormat new SimpleDateFormat("yyyy-MM-dd");return simpleD…...
100天精通Python(实用脚本篇)——第112天:图像处理批量给图片添加水印,防盗必备建议收藏!!!(附上脚本代码)
文章目录 专栏导读1. 图片设置水印的意义?2. 需求3. 实现效果4. 添加全屏水印4.1 单张图片添加全屏水印4.2 批量给多张图片添加全屏水印5. 添加指定位置水印5.1 模块介绍5.2 批量添加脚本实现专栏导读 🔥🔥本文已收录于《100天精通Python从入门到就业》:本专栏专门针对零…...
SpringMVC(全局异常处理.动态接收Ajax请求)
1.全局异常处理 1 异常处理器 基于AOP 用户发起请求, SpringMVC接受请求, SpringMVC加载静态资源问题说明 请求过去了,但没有处理 规则说明:静态资源进入SpringMVC框架之后,没有找到要怎样处理静态资源的方法,所以他们就不解决,也就不显示 解决方法:SpringMVC基于Servlet处理…...
【FastAPI】P1 简单实现 a+b
目录 准备工作代码运行 说明:本文通过 FastAPI 实现返回两个参数 ab 的值; 准备工作 默认读者已准备完善 Python IDE工具以及包管理工具。 首先,需要安装 fastapi 和 uvicorn 库,如果没有请使用 pip 进行安装: pip…...
C#设计模式教程(4):单例模式
单例模式(Singleton Pattern)是一种常用的设计模式,用于确保一个类只有一个实例,并提供一个访问它的全局访问点。在C#中实现单例模式通常有几种不同的方法,这里介绍几种典型的实现方式。 C# 单例模式的各种实现方式 1. 懒汉式(线程不安全) public class Singleton {p…...
常用的git diff命令用法汇总和示例
文章目录 1. 查看工作目录和暂存区的差异2. 查看暂存区和最后一次提交的差异3. 查看两个提交之间的差异4. 查看特定文件的更改5. 查看特定文件在两个提交之间的差异6. 查看分支之间的差异7. 查看某次提交的更改8. 限制diff输出的格式9. 查看一定时间范围内的更改 Git的diff命令…...
一键式Excel分词统计工具:如何轻松打包Python脚本为EXE
一键式Excel分词统计工具:如何轻松打包Python脚本为EXE 写在最前面需求分析直接用Python打包为什么大?为什么要使用conda环境? 将Python脚本打包为一个独立的应用程序1. 编写Python脚本:初步功能实现2. 初步图形用户界面ÿ…...
Windows系统字体尺寸学习
调用GetTextMetrics来获得字体尺寸信息, 函数返回设备描述表中当前选定的字体信息; 返回值到TEXTMETRIC类型的结构中; 返回字段值的单位取决于当前设备描述表映射方式;默认映射方式是MM_TEXT,值的单位是像素; 前7个字…...
SSH隧道技术
SSH隧道 简介 SSH隧道是一种通过SSH协议在两个网络节点之间建立安全通信的技术。它可以用于多种用途,包括加密和保护敏感数据传输、绕过防火墙限制、远程访问内部服务等。 应用: 端口转发:SSH隧道可以将本地端口转发到远程主机上…...
支付功能的实现
1.商户调用第三方支付服务的主要步骤流程? 1.1 表单跳转 前端点击提交支付,请求后端支付接口 支付接口通过阿里api生成表单信息返回给前端页面 同步回调,异步回调参数 请求参数:总金额,外部订单号 公共参数࿱…...
SpringMVC JSON数据处理见解6
6.JSON数据处理 6.1.添加json依赖 springmvc 默认使用jackson作为json类库,不需要修改applicationContext-servlet.xml任何配置,只需引入以下类库springmvc就可以处理json数据: <!--spring-json依赖--> <dependency><groupId>com.f…...
python 读写kafka
1. 安装pykafka pip install pykafka2. 生产者 from pykafka import KafkaClientdef get_kafka_producer(hosts, topics):client KafkaClient(hostshosts)print(client.topics)topic client.topics[topics]producer topic.get_producer()return producer 测试 hosts 19…...
VBA: 如何用VBA遍历文件夹(含子文件夹)里的所有文件
目录 0 原始文件 1 step1:遍历文件夹(不包含子文件)内的文件数 2 step2: 遍历文件夹内的所有子文件夹的名字 3 step3 遍历文件夹的(含子文件)内的所有文件 4 step4 遍历文件夹的(含子文件)内的所有文…...
读写锁:高并发场景的“读写分离“利器
在电商大促期间,商品详情页的访问量是平时的100倍,但商品信息每小时只更新一次。如何让成千上万的用户同时浏览商品,又能在管理员更新价格时保证数据一致性?答案就是:读写锁。 一、读写锁:为什么它能提升10…...
3步掌握智慧树自动学习:解放双手的课程自动化神器
3步掌握智慧树自动学习:解放双手的课程自动化神器 【免费下载链接】zhihuishu 智慧树刷课插件,自动播放下一集、1.5倍速度、无声 项目地址: https://gitcode.com/gh_mirrors/zh/zhihuishu 还在为智慧树平台繁琐的视频学习而烦恼吗?智慧…...
软件工程师在智能体视觉时代的机遇(22)
重磅预告:本专栏将独家连载系列丛书《智能体视觉技术与应用》部分精华内容,该书是世界首套系统阐述“因式智能体”视觉理论与实践的专著,特邀美国 TypeOne 公司首席科学家、斯坦福大学博士 Bohan 担任技术顾问。Bohan先生师从美国三院院士、“…...
即时通讯IM:从聊天工具到企业数字底座
即时通讯IM在2026年已不再只是员工桌面上用来收发消息的软件。它正经历一场深刻的角色蜕变——从“聊天工具”升级为支撑企业核心业务运转的“数字底座”。即时通讯系统已成为支撑企业核心运营的关键基础设施,IM正在被赋予连接一切、打通信息流的关键角色。 这种进化…...
Anthropic《创始人手册:打造AI原生创业公司》Claude(中文精读版)完整38页pdf
Anthropic 在2026年5月发布的官方手册,聚焦 AI 原生创业的全生命周期,拆解从创意、MVP、上线到扩张的四大核心阶段,重构 AI 时代的创业逻辑。 手册核心围绕 “AI 重塑创业模式” 展开,指出 2026 年 AI 已打破技术门槛,…...
STM32F103 平行替代方案全面分析(2026 年最新)
STM32F103 作为全球最经典的 Cortex-M3 MCU,凭借成熟的生态和广泛的应用基础统治了中低端嵌入式市场十余年。但近年来受国际供应链波动影响,其价格持续走高(2026 年 5 月 STM32F103C8T6 批量价约 8-12 元,部分型号甚至超过 20 元&…...
别光盯着分号!从C2143编译错误,聊聊C++预处理和语法解析那些事儿
别光盯着分号!从C2143编译错误,聊聊C预处理和语法解析那些事儿 当你盯着屏幕上的C2143错误,反复检查分号却依然无解时,有没有想过编译器到底"看"到了什么?这个看似简单的语法错误背后,隐藏着从源…...
如何高效获得GitHub社区认可:开发者的3个实用徽章获取策略
如何高效获得GitHub社区认可:开发者的3个实用徽章获取策略 【免费下载链接】community Public feedback discussions for: GitHub Mobile, GitHub Discussions, GitHub Codespaces, GitHub Sponsors, GitHub Issues and more! 项目地址: https://gitcode.com/gh_m…...
实时娱乐资讯获取慢?Perplexity新闻查询延迟优化全解析,3步压降至800ms内
更多请点击: https://codechina.net 第一章:实时娱乐资讯获取慢?Perplexity新闻查询延迟优化全解析,3步压降至800ms内 在高并发娱乐资讯场景下,Perplexity API 默认配置常导致端到端响应延迟突破1.5秒,严…...
360T7路由器无线中继保姆级教程:5分钟搞定信号扩展,告别WiFi死角
360T7路由器无线中继保姆级教程:5分钟搞定信号扩展,告别WiFi死角 你是否经常遇到这样的困扰:客厅WiFi信号满格,但卧室却时断时续;刷剧正到精彩处突然卡顿;游戏团战时延迟飙升...这些恼人的网络死角问题&…...
