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

如何在C语言中使用pthread库实现多线程编程

以下是使用pthread库的基本步骤:

1. 引入pthread头文件

要使用pthread库,我们首先需要在代码中包含头文件pthread.h

#include <pthread.h>
#include <stdio.h>
#include <stdlib.h>
2. 定义线程函数

线程函数是由线程执行的函数。它通常返回一个void *类型,并接收一个void *类型的参数。以下是一个简单的线程函数示例:

void *print_message(void *arg) {char *message = (char *)arg;printf("%s\n", message);return NULL;
}
3. 创建线程

要创建一个线程,我们使用pthread_create()函数。该函数的原型如下:

int pthread_create(pthread_t *thread, const pthread_attr_t *attr, void *(*start_routine)(void *), void *arg);
  • thread:指向线程标识符的指针。
  • attr:用于设置线程属性,通常传递NULL以使用默认属性。
  • start_routine:线程函数的指针。
  • arg:传递给线程函数的参数。
4. 等待线程完成

在主线程中,我们可以使用pthread_join()函数来等待线程的完成。该函数会阻塞主线程,直到指定的线程执行完毕。它的原型如下:

int pthread_join(pthread_t thread, void **retval);
  • thread:要等待的线程标识符。
  • retval:指向存储线程返回值的指针,通常传递NULL
5. 编译和运行程序

要编译使用pthread库的程序,我们需要使用-pthread编译选项。例如:

gcc -o my_program my_program.c -pthread

6.运行编译后的程序:

./my_program

7.示例输出

Thread 1 is running
Thread 2 is running
Both threads have finished.

以下是如何创建线程的示例:

#include <pthread.h>
#include <stdio.h>
#include <stdlib.h>// 线程函数定义
void *print_message(void *arg) {char *message = (char *)arg;  // 将参数转换为字符串printf("%s\n", message);  // 输出线程消息return NULL;
}int main() {pthread_t thread1, thread2;  // 定义两个线程标识符const char *message1 = "Thread 1 is running";  // 线程1的消息const char *message2 = "Thread 2 is running";  // 线程2的消息// 创建线程1if (pthread_create(&thread1, NULL, print_message, (void *)message1) != 0) {perror("Failed to create thread 1");  // 线程创建失败的错误处理return 1;}// 创建线程2if (pthread_create(&thread2, NULL, print_message, (void *)message2) != 0) {perror("Failed to create thread 2");  // 线程创建失败的错误处理return 1;}// 等待线程1完成if (pthread_join(thread1, NULL) != 0) {perror("Failed to join thread 1");  // 等待线程失败的错误处理return 1;}// 等待线程2完成if (pthread_join(thread2, NULL) != 0) {perror("Failed to join thread 2");  // 等待线程失败的错误处理return 1;}printf("Both threads have finished.\n");  // 所有线程完成后的提示信息return 0;
}

在C语言中,main()函数就是主线程运行的地方。创建的其他线程(例如thread1和thread2)是从主线程派生出来的子线程。

主线程的作用

  1. 创建和管理子线程:主线程负责创建其他子线程,使用pthread_create()函数启动这些线程。

  2. 等待子线程完成:主线程通常需要等待子线程完成执行,以确保所有线程的任务都执行完毕。可以使用pthread_join()函数来实现这一点。

  3. 程序的生命周期控制:主线程通常控制程序的整体流程。如果主线程执行结束,整个程序将终止,无论子线程是否完成。因此,主线程的结束时间点必须在所有需要的子线程完成后。

在这个代码中:

  • main()是主线程,它创建了两个子线程thread1thread2
  • 主线程使用pthread_join()函数等待子线程执行完毕后,再输出“Both threads have finished.”。

注意事项

  1. 主线程和子线程的关系:主线程可以创建多个子线程,并使用pthread_join()等待它们完成。子线程也可以相互创建子线程,这会形成一个线程层次结构。

  2. 主线程结束的时机:如果主线程在子线程完成之前结束,程序将提前终止。因此,在大多数情况下,需要确保主线程在所有子线程完成

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • kafak集群搭建-基于kRaft方式
  • 【MySQL-24】万字全面解析<索引>——【介绍&语法&性能分析&使用规则】
  • USER_CLOCK_ROOT
  • 解构赋值的理解
  • python办公自动化:使用`Python-PPTX`创建和操作表格
  • 数学建模学习(121):Python实现模糊AHP(Fuzzy AHP)——从原理到实践
  • JAVA_12
  • 一文搞懂Window、PhoneWindow、DercorView、WindowManage
  • C#计算模数转换器(ADC)的参数DNL、INL、SNR等
  • SQL Server Service Broker故障排除
  • InternVL 多模态模型部署微调实践
  • 骁龙CPU简介
  • Java-数据结构-时间和空间复杂度 (ಥ_ಥ)
  • 耦合和内聚
  • MySQL——多表操作(四)(2)带 EXISTS 关键字的子查询
  • 03Go 类型总结
  • Django 博客开发教程 8 - 博客文章详情页
  • HashMap ConcurrentHashMap
  • IIS 10 PHP CGI 设置 PHP_INI_SCAN_DIR
  • 力扣(LeetCode)56
  • 容器化应用: 在阿里云搭建多节点 Openshift 集群
  • 新书推荐|Windows黑客编程技术详解
  • 移动互联网+智能运营体系搭建=你家有金矿啊!
  • 怎样选择前端框架
  • 走向全栈之MongoDB的使用
  • mysql 慢查询分析工具:pt-query-digest 在mac 上的安装使用 ...
  • Play Store发现SimBad恶意软件,1.5亿Android用户成受害者 ...
  • ​ ​Redis(五)主从复制:主从模式介绍、配置、拓扑(一主一从结构、一主多从结构、树形主从结构)、原理(复制过程、​​​​​​​数据同步psync)、总结
  • ​创新驱动,边缘计算领袖:亚马逊云科技海外服务器服务再进化
  • #07【面试问题整理】嵌入式软件工程师
  • (C语言)输入自定义个数的整数,打印出最大值和最小值
  • (Redis使用系列) Springboot 使用redis实现接口Api限流 十
  • (安卓)跳转应用市场APP详情页的方式
  • (二)WCF的Binding模型
  • (简单) HDU 2612 Find a way,BFS。
  • (理论篇)httpmoudle和httphandler一览
  • (全部习题答案)研究生英语读写教程基础级教师用书PDF|| 研究生英语读写教程提高级教师用书PDF
  • (三)c52学习之旅-点亮LED灯
  • (四)图像的%2线性拉伸
  • (算法)N皇后问题
  • .net 7 上传文件踩坑
  • .net 7和core版 SignalR
  • .net core + vue 搭建前后端分离的框架
  • .net6 webapi log4net完整配置使用流程
  • .net6解除文件上传限制。Multipart body length limit 16384 exceeded
  • .NET框架类在ASP.NET中的使用(2) ——QA
  • .NET实现之(自动更新)
  • .NET中分布式服务
  • ??eclipse的安装配置问题!??
  • @antv/g6 业务场景:流程图
  • []指针
  • [100天算法】-实现 strStr()(day 52)
  • [12] 使用 CUDA 加速排序算法
  • [30期] 我的学习方法
  • [4]CUDA中的向量计算与并行通信模式