Linux多线程【POSIX 线程库】

2024-05-29 17:04
文章标签 linux 线程 多线程 posix

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

POSIX 线程库,也称为 Pthreads(POSIX Threads),是一组用于多线程编程的标准 API。它是 POSIX 标准的一部分,广泛应用于 Unix 和 Unix-like 操作系统(如 Linux 和 macOS)。Pthreads 提供了一套线程创建、管理和同步的函数,使程序能够利用多核处理器的并行计算能力。

主要特点

  1. 线程创建和管理

    • 线程创建:通过 pthread_create 创建新线程。
    • 线程终止:线程可以通过返回、调用 pthread_exit 或其他线程调用 pthread_cancel 来终止。
    • 线程属性:使用 pthread_attr_t 设置线程属性,如栈大小、调度策略等。
  2. 线程同步

    • 互斥锁(Mutex):使用 pthread_mutex_t 实现互斥访问,防止多个线程同时访问共享资源。
    • 条件变量(Condition Variables):通过 pthread_cond_t 实现线程间的条件同步,允许线程在某些条件满足时被唤醒。
    • 读写锁(Read-Write Lock):使用 pthread_rwlock_t 提供更细粒度的控制,允许多个线程读或一个线程写。
    • 屏障(Barrier):使用 pthread_barrier_t 使线程在特定点同步。
  3. 线程属性

    • 线程分离:使用 pthread_detach 将线程设置为分离状态,线程结束后自动释放资源。
    • 线程特定数据(Thread-Specific Data, TSD):通过 pthread_key_t 为每个线程维护特定数据。

主要函数介绍

  1. 线程创建与终止

    • pthread_create: 创建新线程。
    • pthread_exit: 线程终止。
    • pthread_join: 等待指定线程结束。
    • pthread_detach: 将线程设置为分离状态。
    • pthread_cancel: 取消线程。
  2. 线程同步

    • 互斥锁
      • pthread_mutex_init: 初始化互斥锁。
      • pthread_mutex_lock: 加锁。
      • pthread_mutex_trylock: 尝试加锁。
      • pthread_mutex_unlock: 解锁。
      • pthread_mutex_destroy: 销毁互斥锁。
    • 条件变量
      • pthread_cond_init: 初始化条件变量。
      • pthread_cond_wait: 等待条件。
      • pthread_cond_signal: 唤醒一个等待线程。
      • pthread_cond_broadcast: 唤醒所有等待线程。
      • pthread_cond_destroy: 销毁条件变量。
    • 读写锁
      • pthread_rwlock_init: 初始化读写锁。
      • pthread_rwlock_rdlock: 加读锁。
      • pthread_rwlock_wrlock: 加写锁。
      • pthread_rwlock_unlock: 解锁。
      • pthread_rwlock_destroy: 销毁读写锁。
    • 屏障
      • pthread_barrier_init: 初始化屏障。
      • pthread_barrier_wait: 在屏障处等待。
      • pthread_barrier_destroy: 销毁屏障。
  3. 线程属性和特定数据

    • 线程属性
      • pthread_attr_init: 初始化线程属性对象。
      • pthread_attr_destroy: 销毁线程属性对象。
      • pthread_attr_setdetachstate: 设置线程分离状态属性。
      • pthread_attr_getdetachstate: 获取线程分离状态属性。
    • 线程特定数据
      • pthread_key_create: 创建线程特定数据键。
      • pthread_key_delete: 删除线程特定数据键。
      • pthread_setspecific: 设置线程特定数据。
      • pthread_getspecific: 获取线程特定数据。

示例代码

下面是一个简单的多线程示例,展示了如何创建和同步线程:
 

#include <pthread.h>
#include <stdio.h>
#include <stdlib.h>#define NUM_THREADS 5void *print_hello(void *threadid) {long tid;tid = (long) threadid;printf("Hello World! It's me, thread #%ld!\n", tid);pthread_exit(NULL);
}int main() {pthread_t threads[NUM_THREADS];int rc;long t;for (t = 0; t < NUM_THREADS; t++) {printf("In main: creating thread %ld\n", t);rc = pthread_create(&threads[t], NULL, print_hello, (void *) t);if (rc) {printf("ERROR; return code from pthread_create() is %d\n", rc);exit(-1);}}for (t = 0; t < NUM_THREADS; t++) {pthread_join(threads[t], NULL);}pthread_exit(NULL);
}

在这个示例中,主线程创建了 5 个线程,每个线程打印一条消息,然后终止。主线程等待所有线程结束后再终止。

Pthreads 提供了强大的多线程编程功能,使得开发者可以充分利用多核处理器的并行计算能力,提高程序的执行效率。

这篇关于Linux多线程【POSIX 线程库】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Oracle数据库定时备份脚本方式(Linux)

《Oracle数据库定时备份脚本方式(Linux)》文章介绍Oracle数据库自动备份方案,包含主机备份传输与备机解压导入流程,强调需提前全量删除原库数据避免报错,并需配置无密传输、定时任务及验证脚本... 目录说明主机脚本备机上自动导库脚本整个自动备份oracle数据库的过程(建议全程用root用户)总结

Linux如何查看文件权限的命令

《Linux如何查看文件权限的命令》Linux中使用ls-R命令递归查看指定目录及子目录下所有文件和文件夹的权限信息,以列表形式展示权限位、所有者、组等详细内容... 目录linux China编程查看文件权限命令输出结果示例这里是查看tomcat文件夹总结Linux 查看文件权限命令ls -l 文件或文件夹

idea的终端(Terminal)cmd的命令换成linux的命令详解

《idea的终端(Terminal)cmd的命令换成linux的命令详解》本文介绍IDEA配置Git的步骤:安装Git、修改终端设置并重启IDEA,强调顺序,作为个人经验分享,希望提供参考并支持脚本之... 目录一编程、设置前二、前置条件三、android设置四、设置后总结一、php设置前二、前置条件

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方

RabbitMQ消费端单线程与多线程案例讲解

《RabbitMQ消费端单线程与多线程案例讲解》文章解析RabbitMQ消费端单线程与多线程处理机制,说明concurrency控制消费者数量,max-concurrency控制最大线程数,prefe... 目录 一、基础概念详细解释:举个例子:✅ 单消费者 + 单线程消费❌ 单消费者 + 多线程消费❌ 多

Linux系统之lvcreate命令使用解读

《Linux系统之lvcreate命令使用解读》lvcreate是LVM中创建逻辑卷的核心命令,支持线性、条带化、RAID、镜像、快照、瘦池和缓存池等多种类型,实现灵活存储资源管理,需注意空间分配、R... 目录lvcreate命令详解一、命令概述二、语法格式三、核心功能四、选项详解五、使用示例1. 创建逻

Linux下在线安装启动VNC教程

《Linux下在线安装启动VNC教程》本文指导在CentOS7上在线安装VNC,包含安装、配置密码、启动/停止、清理重启步骤及注意事项,强调需安装VNC桌面以避免黑屏,并解决端口冲突和目录权限问题... 目录描述安装VNC安装 VNC 桌面可能遇到的问题总结描js述linux中的VNC就类似于Window

linux下shell脚本启动jar包实现过程

《linux下shell脚本启动jar包实现过程》确保APP_NAME和LOG_FILE位于目录内,首次启动前需手动创建log文件夹,否则报错,此为个人经验,供参考,欢迎支持脚本之家... 目录linux下shell脚本启动jar包样例1样例2总结linux下shell脚本启动jar包样例1#!/bin

Linux之platform平台设备驱动详解

《Linux之platform平台设备驱动详解》Linux设备驱动模型中,Platform总线作为虚拟总线统一管理无物理总线依赖的嵌入式设备,通过platform_driver和platform_de... 目录platform驱动注册platform设备注册设备树Platform驱动和设备的关系总结在 l

linux批量替换文件内容的实现方式

《linux批量替换文件内容的实现方式》本文总结了Linux中批量替换文件内容的几种方法,包括使用sed替换文件夹内所有文件、单个文件内容及逐行字符串,强调使用反引号和绝对路径,并分享个人经验供参考... 目录一、linux批量替换文件内容 二、替换文件内所有匹配的字符串 三、替换每一行中全部str1为st