Linux中线程池及gdb调试多线程

2024-02-01 01:20

本文主要是介绍Linux中线程池及gdb调试多线程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

线程池的概念

  • 概念:
    通俗的讲就是一个线程的池子,可以循环的完成任务的一组线程集合
  • 必要性:
    我们平时创建一个线程,完成某一个任务,等待线程的退出。但当需要创建大量的线程时,假设T1为创建线程时间,T2为在线程任务执行时间,T3为线程销毁时间,当 T1+T3 > T2,这时候就不划算了,使用线程池可以降低频繁创建和销毁线程所带来的开销,任务处理时间比较短的时候这个好处非常显著。
  • 线程池的基本结构:
    1 任务队列,存储需要处理的任务,由工作线程来处理这些任务
    2 线程池工作线程,它是任务队列任务的消费者,等待新任务的信号,每当任务来的时候,都会被分配到一个工作线程
    在这里插入图片描述
  • 线程池的实现
    • 创建线程池的基本结构:
      任务队列链表
      typedef struct Task;
      线程池结构体
      typedef struct ThreadPool;
    • 代码实现:
      在这里插入图片描述
    • 线程池的初始化:
      pool_init()
      {
      创建一个线程池结构
      实现任务队列互斥锁和条件变量的初始化
      创建n个工作线程
      }
    • 代码实现:
      在这里插入图片描述
    • 线程池添加任务
      pool_add_task
      {
      判断是否有空闲的工作线程
      给任务队列添加一个节点
      给工作线程发送信号newtask
      }
    • 代码实现:
      在这里插入图片描述
    • 实现工作线程
      workThread
      {
      while(1){
      等待newtask任务信号
      从任务队列中删除节点
      执行任务
      }
      }
    • 代码实现:
      在这里插入图片描述
    • 程池的销毁
      pool_destory
      {
      删除任务队列链表所有节点,释放空间
      删除所有的互斥锁条件变量
      删除线程池,释放空间
      }
    • 代码如下:
      在这里插入图片描述
    • main函数如下:
      在这里插入图片描述
      编译错误:
      error: ‘ThreadPool {aka struct ThreadPool}’ has no member named ‘head’
      意义:ThreadPool 结构体没有head这个成员。
      解决:检查是否拼写错误。
      error: too few arguments to function ‘pthread_mutex_init’
      意思:pthread_mutex_init这个函数参数少了
      解决:检查函数的参数,添加对应的参数

线程的GDB调试

  • 显示线程
    info thread
    切换线程
    thread id
    GDB为特定线程设置断点
    break location thread id
    GDB设置线程锁,
    set scheduler-locking on/off
    on:其他线程会暂停。可以单独调试一个线程
  • 写一个简单的例子:
    在这里插入图片描述
  • 然后进行调试
    在这里插入图片描述
  • 如何让线程单独调试运行如下:
    在这里插入图片描述
  • 指定线程断点必须确保有线程运行在,因此需要先设置公共断点

这篇关于Linux中线程池及gdb调试多线程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/665644

相关文章

linux-基础知识3

打包和压缩 zip 安装zip软件包 yum -y install zip unzip 压缩打包命令: zip -q -r -d -u 压缩包文件名 目录和文件名列表 -q:不显示命令执行过程-r:递归处理,打包各级子目录和文件-u:把文件增加/替换到压缩包中-d:从压缩包中删除指定的文件 解压:unzip 压缩包名 打包文件 把压缩包从服务器下载到本地 把压缩包上传到服务器(zip

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

ASIO网络调试助手之一:简介

多年前,写过几篇《Boost.Asio C++网络编程》的学习文章,一直没机会实践。最近项目中用到了Asio,于是抽空写了个网络调试助手。 开发环境: Win10 Qt5.12.6 + Asio(standalone) + spdlog 支持协议: UDP + TCP Client + TCP Server 独立的Asio(http://www.think-async.com)只包含了头文件,不依

如何在Visual Studio中调试.NET源码

今天偶然在看别人代码时,发现在他的代码里使用了Any判断List<T>是否为空。 我一般的做法是先判断是否为null,再判断Count。 看了一下Count的源码如下: 1 [__DynamicallyInvokable]2 public int Count3 {4 [__DynamicallyInvokable]5 get

Linux_kernel驱动开发11

一、改回nfs方式挂载根文件系统         在产品将要上线之前,需要制作不同类型格式的根文件系统         在产品研发阶段,我们还是需要使用nfs的方式挂载根文件系统         优点:可以直接在上位机中修改文件系统内容,延长EMMC的寿命         【1】重启上位机nfs服务         sudo service nfs-kernel-server resta

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念

Linux服务器Java启动脚本

Linux服务器Java启动脚本 1、初版2、优化版本3、常用脚本仓库 本文章介绍了如何在Linux服务器上执行Java并启动jar包, 通常我们会使用nohup直接启动,但是还是需要手动停止然后再次启动, 那如何更优雅的在服务器上启动jar包呢,让我们一起探讨一下吧。 1、初版 第一个版本是常用的做法,直接使用nohup后台启动jar包, 并将日志输出到当前文件夹n