【linux 多线程并发】多线程的控制,挂起线程暂停运行,直到唤醒线程,取消线程运行,可以设置合适的取消点属性避免不安全点被中止

这篇具有很好参考价值的文章主要介绍了【linux 多线程并发】多线程的控制,挂起线程暂停运行,直到唤醒线程,取消线程运行,可以设置合适的取消点属性避免不安全点被中止。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

线程运行控制

专栏内容

  • 参天引擎内核架构
    本专栏一起来聊聊参天引擎内核架构,以及如何实现多机的数据库节点的多读多写,与传统主备,MPP的区别,技术难点的分析,数据元数据同步,多主节点的情况下对故障容灾的支持。

  • 手写数据库toadb
    本专栏主要介绍如何从零开发,开发的步骤,以及开发过程中的涉及的原理,遇到的问题等,让大家能跟上并且可以一起开发,让每个需要的人成为参与者。
    本专栏会定期更新,对应的代码也会定期更新,每个阶段的代码会打上tag,方便阶段学习。

开源贡献

  • toadb开源库

个人主页:我的主页
管理社区:开源数据库
座右铭:天行健,君子以自强不息;地势坤,君子以厚德载物.

前言

现代的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
如有错误或者疏漏欢迎指出,互相学习。文章来源地址https://www.toymoban.com/news/detail-807709.html

到了这里,关于【linux 多线程并发】多线程的控制,挂起线程暂停运行,直到唤醒线程,取消线程运行,可以设置合适的取消点属性避免不安全点被中止的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • C#灵活控制多线程的状态(开始暂停继续取消)

    ManualResetEvent 是一个同步基元,用于在多线程环境中协调线程的执行。它提供了两种状态:终止状态和非终止状态。 在终止状态下, ManualResetEvent 允许线程继续执行。而在非终止状态下, ManualResetEvent 会阻塞线程,直到它的状态变为终止状态。 ManualResetEvent 类有以下几个常用

    2024年02月02日
    浏览(38)
  • 【Linux】进程状态&&僵尸进程和孤儿进程&&阻塞、挂起和运行

    个人主页 : zxctscl 如有转载请先通知 上一篇博客中提到 【Linux】进程初步理解,这次继续来分享与进程有关的知识。 Linux的进程状态就是struct task_struct内部的一个属性。 为了弄明白正在运行的进程是什么意思,我们需要知道进程的不同状态。一个进程可以有几个状态(在

    2024年04月14日
    浏览(38)
  • python--pyQt5 页面刷新\线程刷新\界面卡顿 --- 多线程处理(线程的开始/暂停/恢复/取消)同时运行两个不同的线程 pyside6

    参考:https://blog.csdn.net/zx520113/article/details/86598658 PyQt5中使用QTimer定时刷新:当要执行可能会超过设定时间的代码 刷新界面命令:QApplication.processEvents() 对于执行很耗时的程序来说,由于PyQt需要等待程序执行完毕才能进行下一步,这个过程表现在界面上就是卡顿,而如果需要

    2024年03月25日
    浏览(49)
  • Java并发(四)----线程运行原理

    1.1 栈与栈帧   Java Virtual Machine Stacks (Java 虚拟机栈 JVM) 我们都知道 JVM 中由堆、栈、方法区所组成,其中栈内存是给谁用的呢?其实就是线程,每个线程启动后,虚拟机就会为其分配一块栈内存。 每个栈由多个栈帧(Frame)组成,对应着每次方法调用时所占用的内存 每个

    2024年02月02日
    浏览(41)
  • MySQL多线程并发控制技巧分享

    在高并发的应用场景下,数据库的性能瓶颈往往出现在并发读写上。为了提高数据库的并发性能,我们需要对MySQL的多线程进行有效的并发控制。本文将分享一些MySQL多线程并发控制的技巧,帮助大家更好地理解和优化MySQL的并发性能。 调整线程缓存大小 MySQL中的线程缓存是一

    2024年02月06日
    浏览(97)
  • C++_linux下_非阻塞键盘控制_程序暂停和继续

    在程序执行过程中,点击键盘p按键(pause), 程序暂停, 点击键盘上的n按键(next),程序继续执行 可以使用opencv中相关函数简单实现: 空格键暂停, 其它任意键继续: 参考: linux下实现键盘的无阻塞输入_fd_zero(rfds);-CSDN博客 拓展: 每隔1秒,for 循环执行一次: 参考: select()  fd_set 原理介绍

    2024年02月08日
    浏览(38)
  • 【Linux】进程的状态(运行、阻塞、挂起)详解,揭开孤儿进程和僵尸进程的面纱,一篇文章万字讲透!!!!进程的学习②

    目录 1.进程排队 时间片 时间片的分配 结构体内存对齐 偏移量补充 对齐规则  为什么会有对齐 2.操作系统学科层面对进程状态的理解 2.1进程的状态理解 ①我们说所谓的状态就是一个整型变量,是task_struct中的一个整型变量 ②.状态决定了接下来的动作 2.2运行状态 2.3 阻塞状

    2024年04月14日
    浏览(46)
  • 金三银四-解锁Java并发编程的艺术:掌握多线程、同步和并发控制的精髓

            又要快到一年一度的金三银四,开始复习啦~!         每天一点点。。 目录 一、Java中的volatile有什么作用? 二、解释Java中的synchronized及其工作原理。 三、Java中的CAS操作是什么?它如何实现无锁编程? 四、讲述Java中的Lock接口及其与synchronized的区别

    2024年01月17日
    浏览(49)
  • C++_linux下_非阻塞键盘控制_程序暂停和继续/for循环每隔2s执行一次

    在程序执行过程中,点击键盘p按键(pause), 程序暂停, 点击键盘上的n按键(next),程序继续执行 可以使用opencv中相关函数简单实现: 空格键暂停, 其它任意键继续: 参考: linux下实现键盘的无阻塞输入_fd_zero(rfds);-CSDN博客 拓展: 每隔1秒,for 循环执行一次: 参考: select()  fd_set 原理介绍

    2024年02月03日
    浏览(35)
  • Windows线程挂起和Context

    1、SuspendThread用来暂停一个线程的执行,线程暂停时,不会被调度执行 2、ResumeThread用来恢复一个暂停线程的执行(一个暂停的线程无法调用这个方法来恢复自己, 3、因为暂停的线程不可能被执行)暂停县城总是立即被暂停,而不管被暂停的线程执行到了哪个指令 线程内核对象

    2024年02月13日
    浏览(31)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包