当前位置: 首页 > backend >正文

【中间件】brpc_基础_bthread头文件

bthread.h学习笔记

源码

1 概述

bthread.h 定义了一个用户级线程库,提供类似 POSIX 线程(pthread)的功能,但针对高并发和调度优化进行了扩展。支持线程管理、同步原语、中断机制、线程特定数据等功能,适用于需要高效协程管理的场景。


2 核心功能模块

2.1 线程创建与管理

  • 启动模式
    • Urgent (bthread_start_urgent):立即切换至新线程,适合高优先级任务。
    • Background (bthread_start_background):类似 pthread_create,启动后返回,新线程可能延迟执行。
  • 线程控制
    • bthread_exit:终止当前线程。
    • bthread_join:等待线程结束(所有线程默认可连接,但返回值固定为 NULL,需通过参数传递结果)。
    • bthread_self:获取当前线程 ID。
    • bthread_yield:主动让出 CPU(调度公平性可能不足)。

2.2 中断与停止

  • 中断机制
    • bthread_interrupt:唤醒阻塞中的线程(如 bthread_usleep 返回错误,bthread_cond_wait 唤醒)。
    • bthread_stop:设置停止标志并中断线程,需线程内部检查 bthread_stopped 退出。
  • 协作式退出:需用户代码主动检查停止标志,避免资源泄漏。

2.3 同步原语

  • 互斥锁 (bthread_mutex_*)
    • 初始化时属性可能被忽略(建议传 NULL)。
    • 支持 trylocktimedlock
  • 条件变量 (bthread_cond_*)
    • 需与互斥锁配合使用,支持超时等待 (bthread_cond_timedwait)。
  • 读写锁 (bthread_rwlock_*)
    • 支持读写分离锁,可配置偏好(读优先/写优先)。
  • 信号量 (bthread_sem_*)
    • 提供 post_n 批量释放信号量。
  • 屏障 (bthread_barrier_*)
    • 多线程同步点,等待指定数量的线程到达。

2.4 线程特定数据 (TSD)

  • key管理
    • bthread_key_create/bthread_key_delete:创建/销毁键。
    • bthread_setspecific/bthread_getspecific:设置/获取线程本地数据。
  • 性能提示:短生命周期线程慎用 TSD,避免频繁分配键表。

2.5 调度与并发控制

  • 并发度调整
    • bthread_setconcurrency:设置工作线程(底层 pthread)数量。
    • 按标签管理bthread_setconcurrency_by_tag 支持为不同任务类别分配独立并发度。
  • CPU 时间统计
    • bthread_cpu_clock_ns:获取线程 CPU 时间(需启用 bthread_enable_cpu_clock_stat)。

2.6 工具函数

  • 一次性初始化
    • bthread_once:确保初始化代码仅执行一次。
  • 列表管理
    • bthread_list_*:批量管理线程(非线程安全,需外部同步)。

3 关键设计特点

  1. 协作式调度

    • bthread_yield 和同步原语可能触发线程切换,但调度公平性有限,需避免长耗时操作独占 CPU。
  2. 轻量级中断

    • 通过标志位 + 中断唤醒协作退出,避免强制终止导致的资源问题。
  3. 高效同步

    • 同步原语可能基于用户态实现,减少内核切换开销(如信号量 post_n 批量操作)。
  4. 标签化并发

    • 允许不同任务类型(如计算密集型、I/O 密集型)使用独立并发度,优化资源利用。

4 使用注意事项

  • 错误处理:函数返回 0 表示成功,错误码需通过返回值或 errno 检查。
  • 线程生命周期:短线程慎用 TSD,避免性能损耗。
  • 中断兼容性:不同阻塞函数对中断的反应不同(如 bthread_usleep 返回 ESTOP,而 bthread_mutex_lock 不受影响)。
  • 资源回收:所有线程默认可连接,但需手动调用 bthread_join 确保资源释放。

5 示例场景

// 创建高优先级线程并等待
bthread_t tid;
bthread_start_urgent(&tid, NULL, my_func, my_args);
bthread_join(tid, NULL);// 使用条件变量同步
bthread_mutex_lock(&mutex);
while (!condition) {bthread_cond_wait(&cond, &mutex);
}
bthread_mutex_unlock(&mutex);// 中断处理
void* worker(void* arg) {while (!bthread_stopped(bthread_self())) {// 工作逻辑}return NULL;
}
bthread_stop(tid); // 触发退出

6 总结

bthread 提供了高性能的用户级线程管理,适用于需要细粒度并发控制的场景。开发者需结合其协作式调度、中断机制和同步原语特性,合理设计线程逻辑,以充分发挥其优势。

http://www.xdnf.cn/news/3559.html

相关文章:

  • 【AI面试准备】Git与CI/CD及单元测试实战指南
  • 从 “零” 做个开源音乐软件“SteadyBeat”吧!<1> 准备
  • NVIDIA NPP 库入门
  • c++_csp-j算法 (6)_高精度算法(加减乘除)
  • PostgreSQL:pgJDBC 下载和安装
  • TensorZero开源程序创建了一个反馈循环来优化 LLM 应用程序,将生产数据转化为更智能、更快、更便宜的模型
  • Leetcode刷题记录26——轮转数组
  • 数字时代,如何为个人信息与隐私筑牢安全防线?
  • Laravel Octane 项目加速与静态资源优化指南
  • MySQL基本查询(二)
  • QT6(32)4.5常用按钮组件:Button 例题的代码实现
  • 【python】【UV】一篇文章学完新一代 Python 环境与包管理器使用指南
  • 手机的数据楚门世界是如何推送的
  • word交叉引用图片、表格——只引用编号的处理方法
  • 4.27-5.4学习周报
  • 【KWDB 创作者计划】技术解读:多模架构、高效时序数据处理与分布式实现
  • ubuntu的libc 库被我 sudo apt-get --reinstall install libc6搞没了
  • WPF之ProgressBar控件详解
  • 学习:困?
  • Nginx部署Vue+ElementPlus应用案例(基于腾讯云)
  • 基于Redis实现-UV统计
  • Linux:系统延迟任务及定时任务
  • 柔性PZT压电薄膜多维力传感器在微创手术机器人的应用
  • [英语单词] from under
  • 【STM32】定时器
  • React memo
  • 《操作系统真象还原》调试总结篇
  • 在pycharm profession 2020.3上安装使用xlwings
  • 【CTFer成长之路】XSS的魔力
  • 个人健康中枢的多元化AI硬件革新与精准健康路径探析