线程 锁(二)





线程 锁(二)

线程 锁(二)

线程


读写锁

  1. 当读写锁是加写锁时, 其他试图加写锁的线程都会被阻塞, 加读锁的也会被阻塞到写锁释放为止.
  2. 读写锁是加写锁时, 其他试图加写锁的线程可以共享数据.

读写锁的函数

    
    
    
    
  1. #include
  2. // 分配一个读写锁
  3. int pthread_rwlock_init(pthread_rwlock_t *restrict rwlock, const pthread_rwlockattr_t *restrict *attr)
  4. // 释放读写锁
  5. int pthread_rwlock_destroy(pthread_rwlock_t rwlock)
  6. // 成功, 返回 0; 失败. 返回错误编码
  7. // 静态分配:
  8. pthread_rwlock_t t = PTHREAD_RWLOCK_INITALLZER;

读写锁在使用之前一定要初始化, 在释放他们底层的内存之前必须销毁
同样, 如果在调用pthread_rwlock_destroy之前就释放读写锁的空间, 那么分配的空间就会丢失

    
    
    
    
  1. #include
  2. int pthread_rwlock_rlock(pthread_rwlock_t *rwlock) // 读锁
  3. int pthread_rwlock_wlock(pthread_rwlock_t *rwlock) // 写锁
  4. int pthread_rwlock_unlock(pthread_rwlock_t *rwlock) // 解锁
  5. // 成功, 返回 0; 失败, 返回错误编码

条件变量

1. 条件变量给多个线程提供一个汇合的机会.
2. 条件变量与互斥量一起使用时, 允许线程无竞争的方式等待特定的条件变量执行.
3. 条件本身由互斥量保护的. 线程在改变条件之前应该首先锁住互斥量

条件变量创建

    
    
    
    
  1. #include
  2. int pthread_cond_init(pthread_cond_t *restrict cond, const pthread_condattr_t *restrict attr)
  3. int pthread_cond_destroy(pthread_cond_t *restrict cond)
  4. // 成功, 返回 0; 失败, 返回错误编码

变量锁

    
    
    
    
  1. #include
  2. int pthread_cond_wait(pthread_cond_t *restrict cond, pthread_mutex_t *restrict mutex)
  3. // tsptr : 等待时间
  4. int pthread_cond_timedwait(pthread_cond_t *restrict cond, pthread_mutex_t *restrict mutex, const struct timespec *restrict tsptr)
  5. // 成功, 返回 0; 失败, 返回错误编码

唤醒等待条件的线程
这是再给线程或条件发信号

    
    
    
    
  1. #include
  2. // 至少能唤醒一个等待条件的线程
  3. int pthread_cond_signal(pthread_cond_t *cond)
  4. // 唤醒所有等待条件的线程
  5. int pthread_cond_broadcast(pthread_cond_t *cond)
  6. // 成功, 返回 0; 失败, 返回错误编码

自己照着一篇博主写的代码, 发现写的并不是很好
这里是博主的地址, 写的很详尽的, 我也就不再多写了, 毕竟写的也不容易, 太花时间了, 还要准备上课, 不过写的希望对大家有帮助
地址 : https://www.cnblogs.com/yuuyuu/p/5140875.html


你可能感兴趣的:(UNIX高级编程随笔,unix编程学习)