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

brpc: bthread使用

使用bthread并发编程

#include <gflags/gflags.h>
#include <butil/logging.h>
#include <bthread/bthread.h>static void* func(void* args) {std::string* num = static_cast<std::string*>(args);for(int i = 0; i < 5; i++) {LOG(INFO) << *num;bthread_usleep(1000);}return NULL;
}int main() {bthread_t th1, th2;std::string a = "bthread:A", b = "bthread:B", c = "bthread:C";if (bthread_start_background(&th1, NULL, func, static_cast<void*>(&a)) != 0) {LOG(ERROR) << "Fail to create bthread for part1";}if (bthread_start_background(&th2, NULL, func, static_cast<void*>(&b)) != 0) {LOG(ERROR) << "Fail to create bthread for part2";}func(static_cast<void*>(&c));bthread_join(th1, NULL);bthread_join(th2, NULL);
}

thread 栈切换事例

#include <bthread/context.h>
#include <iostream>::bthread_fcontext_t fc1;
::bthread_fcontext_t fc2;
::bthread_fcontext_t fc_tmp;
intptr_t  g_num1 = 0;
intptr_t  g_num2 = 0;static void jumper1(intptr_t param) {for(int i = 0; i < 9; i++) {printf("context1: g_num1 = %ld, then jump to context2\n", ++g_num1);::bthread_jump_fcontext(&fc1, fc2, 0);}// 最后结尾,jump到原始上下文中,继续执行printf("context1: g_num1 = %ld, finally, jump to main\n", ++g_num1);::bthread_jump_fcontext(&fc1, fc_tmp, 0);
}
static void jumper2(intptr_t param) {for(int i = 0; i < 10; i++) {printf("context2: g_num2 = %ld, then jump to context1\n", ++g_num2);::bthread_jump_fcontext(&fc2, fc1, 0);}
}int main() {static const std::size_t stack_size = 8192;// 创建两个上下文void *sp1 = ::malloc(stack_size);fc1 = ::bthread_make_fcontext((char*)sp1 + stack_size, stack_size, jumper1);void *sp2 = ::malloc(stack_size);fc2 = ::bthread_make_fcontext((char*)sp2 + stack_size, stack_size, jumper2); // 将当前上下文保存到fc_tmp,并切换上下为fc2::bthread_jump_fcontext(&fc_tmp, fc2, 0);printf("done\n");::free(sp1);::free(sp2);return 0;
}

ExecutionQueue 的使用

ExecutionQueue是一个mpsc队列,即线程安全的多生产者单消费者队列

#include <bthread/execution_queue.h>
#include <bthread/bthread.h>
class DemoTask {
public:void run(int);
};void DemoTask::run(int count) {LOG(INFO) << "DemoTask::run(" << count << ")";
}int comsume(void *meta, bthread::TaskIterator<DemoTask*> &iter) {if(iter.is_queue_stopped()) {return 0;}int count = 0;for(; iter; ++iter) {DemoTask *task = *iter;task->run(++count);}return 0;
}int main() {bthread::ExecutionQueueId<DemoTask*> exe_queue;int ret = bthread::execution_queue_start(&exe_queue, nullptr, comsume, nullptr);DemoTask *task = new DemoTask();ret = bthread::execution_queue_execute(exe_queue, task);bthread_usleep(10);
}
http://www.lryc.cn/news/339673.html

相关文章:

  • H.265视频直播点播录像EasyPlayer.js流媒体播放器用户常见问题及解答
  • 蓝桥杯杂题选做
  • 【HTML】简单制作一个分形动画
  • JVM修炼之路【11】- 解决内存溢出、内存泄漏 以及相关案例
  • Java面试题:描述Java 17中的密封接口及其用途
  • C++11的新特性
  • 【C语言__动态内存管理__复习篇6】
  • C语言 | Leetcode C语言题解之第30题串联所有单词的子串
  • 大数据dolphinscheduler 本地容器化安装
  • 简单的车牌号识别
  • openGauss学习笔记-261 openGauss性能调优-使用Plan Hint进行调优-将部分Error降级为Warning的Hint
  • CSS水波纹效果
  • 迭代器模式:优雅地遍历数据集合
  • c++总结笔记(一)
  • [python][gradio]chatbot控件用法
  • Sublime Text下载,安装,安装插件管理器,下载汉化插件
  • c++ ,stl经常出现的<>尖括号其实就是模板类的实例化
  • goproxy 简单介绍 及一键安装脚本
  • Day13-Python基础学习之数据分析案例
  • 研究生,该学单片机还是plc。?
  • 【Java】导出Mysql表表结构与注释数据字典
  • 第07-2章 TCP/IP模型
  • 【办公类-21-15】 20240410三级育婴师 712道单选题(题目与答案合并word)
  • Vue3+Vant开发:登录功能
  • Linux程序调试优化(1)——内存占用详解及优化思路
  • 高效解决Visual Studio Code中文乱码问题
  • springboot接口提高查询速度方法
  • 如何在苹果手机上安装iOS应用的.ipa文件?
  • IDEA pom.xml显示灰色并被划线
  • 玄子Share-使用 Pycharm 执行 Shell 脚本