`
javatoyou
  • 浏览: 1083790 次
  • 性别: Icon_minigender_2
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

pthread 同步机制

 
阅读更多

1.互斥量

互斥量mutex是mutual-exclusion简写,通过互斥量可以保证数据在同一时刻只能被一个线程访问,其他线程阻塞,锁住互斥量的线程释放互斥量时,阻塞在互斥量上的线程都被唤醒,竞争这个互斥量,最终只有一个线程获得互斥量锁定继续运行,其他线程继续进入阻塞状态。

互斥量用pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER 或者
int pthread_mutex_init(pthread_mutex_t *restrict mutex,
const pthread_mutexattr_t *restrict attr)
进行初始化,前者用于静态初始化,后者用于对malloc分配的内存初始化。
互斥量用int pthread_mutex_destroy(pthread_mutex_t *mutex)销毁。

int pthread_mutex_lock(pthread_mutex_t *mutex)锁住互斥量mutex,如果有线程已经锁住互斥量mutex,当前线程阻塞。连续两次调用会造成当前线程和其他等待互斥量mutex的线程死锁。
int pthread_mutex_trylock(pthread_mutex_t *mutex)尝试锁住互斥量mutex,如果有线程已经锁住互斥量mutex,立即返回EBUSY。连续两次调用不会造成死锁。
int pthread_mutex_unlock(pthread_mutex_t *mutex)解锁互斥量mutex,前提是当前线程已经锁住互斥量mutex。

在使用互斥量进行线程同步的时候,避免死锁的方法有两种:
(1)规定多个互斥量加所的秩序
(2)线程需要锁定多个互斥量时,用pthread_mutex_lock锁住第一个互斥量,然后用pthread_mutex_trylock尝试锁住其他互斥量,如果尝试失败就回溯解锁上一个锁住的互斥量。
方法1使用简单,在互斥量不多、系统简单的情况下很实用,效率很高,但是当系统比较复杂时,往往很难严格规定互斥量的加锁顺序,方法2比较通用,但是尝试失败时回溯解锁效率比较低,也应谨慎使用。

2.读写锁

读写锁read-write-lock和互斥量mutex相似,但是它比互斥量有更好的并行性,它允许多个进程同时读,只允许一个进程写。互斥量有锁住和解锁两种状态,而读写锁有三种状态:读锁、写锁和解锁。读锁状态时允许其他线程可以获得读锁但是不能获得写锁,写锁状态时其他线程不能获得读锁和写锁。
读写锁的使用方式与互斥量相似:
int pthread_rwlock_init(pthread_rwlock_t *restrict rwlock,
const pthread_rwlockattr_t *restrict attr);
int pthread_rwlock_destroy(pthread_rwlock_t *rwlock);

int pthread_rwlock_rdlock(pthread_rwlock_t *rwlock);
int pthread_rwlock_wrlock(pthread_rwlock_t *rwlock);
int pthread_rwlock_unlock(pthread_rwlock_t *rwlock);

int pthread_rwlock_tryrdlock(pthread_rwlock_t *rwlock);
int pthread_rwlock_trywrlock(pthread_rwlock_t *rwlock);

在很多实现中,为了避免很多读锁请求阻塞写锁请求,当读写锁处于读锁状态时如果一个写锁和多个读锁请求到达,则读锁被释放时写锁请求得到响应,其他读锁请求继续阻塞。这种实现方式常被称作写者优先模式。
读写锁很适合与对数据的访问中只读操作比较多,更改操作比较少的情况

分享到:
评论

相关推荐

    pthread.zip_C++_pthread windows

    线程同步是多线程编程中的关键部分,pthread库提供了多种同步机制,包括: - 互斥锁(Mutex):`pthread_mutex_t`用于保护共享资源,同一时间只允许一个线程访问。 - 条件变量(Condition Variable):`pthread_...

    Pthread互斥问题

    在操作系统领域,线程间的同步和互斥是多线程编程中的核心概念。"Pthread互斥问题"指的是使用POSIX线程库(Pthreads)处理的进程...在`OSprojectPthread`这个项目中,你可能会看到如何在实际代码中实现这样的同步机制。

    pthread, window pthread

    然而,多线程编程也带来了一些挑战,如死锁、竞态条件和资源泄露等问题,因此理解线程安全和同步机制至关重要。 总的来说,pthread库是多线程编程的一个强大工具,无论是在传统的Unix系统还是Windows环境下,它都...

    Windows可使用的pthread库

    2. **线程同步**:pthread库提供了多种同步机制,包括互斥锁(`pthread_mutex_t`)、条件变量(`pthread_cond_t`)、信号量(`pthread_semaphore_t`)和读写锁(`pthread_rwlock_t`)。这些同步原语有助于防止数据...

    JNI 多线程同步机制的源码实现

    在多线程环境中,当涉及到与本地代码(如C/C++)的交互时,同步机制显得尤为重要,以防止数据竞争和不一致的情况。本文将深入探讨如何使用JNI实现多线程同步,并通过源码来解析这一过程。 1. **JNI基础知识** JNI...

    [并发并行]_[线程同步]_[pthread_once 实现单例模式分析]

    在IT行业中,线程同步是多线程编程中的一个核心概念...通常情况下,这可能是一个示例程序或者测试用例,用于演示或验证 `pthread_once` 或 Win32 同步机制的实现。如果需要进一步的分析,需要查看这个文件的具体内容。

    POSIX Pthread 编程资料大全

    Pthread提供以下同步机制: - 互斥量(Mutex):通过加锁和解锁操作确保同一时间只有一个线程访问临界区。 - 读写锁(Read-Write Locks):允许多个读取者同时访问资源,但写入者独占。 - 条件变量(Condition ...

    线程间同步机制 读写锁通信机制 线程与信号

    在Linux高级程序设计中,主要介绍了三种线程同步机制:互斥锁、条件变量和读写锁,以及线程与信号的交互。 1. **互斥锁通信机制**: 互斥锁是用于保护临界区的一种机制,确保同一时间只有一个线程能访问共享资源。...

    pthread多线程c++动库下载

    pthread是POSIX线程库,它为C++编程...合理地使用锁(mutex)、信号量、条件变量等同步机制是至关重要的。同时,了解pthread的线程生命周期管理、线程局部存储(TLS)以及取消点等特性也是编写高效多线程代码的基础。

    2_pthread_sync.tgz

    在`2_pthread_sync`这个压缩包中,我们可以期待找到使用这些同步机制的实例代码。这些示例可能涵盖了如何创建线程、如何使用上述同步原语以及如何在多线程环境中避免竞态条件等问题。通过分析和运行这些代码,我们...

    windows下可用的pthread库

    此外,pthread还提供了信号量(semaphore)、互斥锁(mutex)、条件变量(condition variable)等同步机制,使得多线程间的协作更为高效和安全。 2. **在Windows下的移植** 要在Windows环境下使用pthread库,首先...

    Pthread Tutorial

    互斥锁(mutex)是最常见的同步机制之一,用于保护临界区,确保一次只有一个线程访问共享资源。`pthread_mutex_t`类型的变量用于表示互斥锁。`pthread_mutex_lock()`和`pthread_mutex_unlock()`分别用于锁定和解锁...

    vs2017无法打开源文件pthread

    - 多线程编程涉及并发和同步问题,正确使用mutex、条件变量等同步机制是至关重要的,否则可能导致数据竞争和死锁。 总结来说,解决"vs2017无法打开源文件pthread"的问题,主要涉及在Windows环境下适配pthread库,这...

    Pthread多线程编程指南

    - **信号量**:`sem_t`提供了一种计数型同步机制,可以控制对共享资源的访问数量。 5. **线程取消**:`pthread_cancel()`函数可以请求取消一个线程,而`pthread_setcancelstate()`和`pthread_setcanceltype()`则...

    Posix Pthread API 总结文档

    Posix Pthread API 提供了多种线程同步机制,如互斥锁、条件变量、信号量等。 1. 创建互斥锁 pthread_mutex_init 函数用于创建一个互斥锁,该函数需要一个参数:互斥锁的地址。 2. 锁定互斥锁 pthread_mutex_...

    Linux下多线程编程-Pthread与Semaphore的使用.doc

    pthread 提供了创建和管理线程的功能,而 Semaphore 提供了同步机制来控制多个线程的访问顺序。 知识点: 1. Linux 下的多线程编程是通过使用 POSIX 线程接口,称为 pthread 实现的。 2. 要编写 Linux 下的多线程...

    pthread 线程标准 (中)

    综上所述,“pthread线程标准(中)”不仅涉及基本的线程创建、管理与同步机制,还包括了线程优先级、调度策略、取消机制和线程局部存储等高级特性。掌握这些知识点,对于编写高效、稳定、易于维护的多线程程序至关...

    windows下使用pthread库

    - **线程同步**:pthread库提供了多种同步机制,如互斥量(`pthread_mutex_t`)、条件变量(`pthread_cond_t`)、信号量(`sem_t`)等。这些在Windows下也能正常工作,但需要注意,Windows的同步原语(如Mutex、...

    Pthread Primer

    2. **线程同步**:Pthread提供了多种同步机制,如互斥锁(`pthread_mutex_t`)、条件变量(`pthread_cond_t`)和信号量(`sem_t`)。互斥锁用于保护共享资源,确保同一时间只有一个线程访问;条件变量则允许线程在...

    pthread-win32演示程序

    3. **线程同步**:pthread-win32库提供了多种同步机制,如互斥量(`pthread_mutex_t`)、条件变量(`pthread_cond_t`)和信号量(`sem_t`)。这些机制用于控制对共享资源的访问,防止竞态条件的发生。 - **互斥量*...

Global site tag (gtag.js) - Google Analytics