读写锁

http://www.cnblogs.com/Anker/archive/2013/01/09/2853137.html


读写锁与互斥量类似,不过读写锁允许更高的并发性,互斥量要么是锁住状态,要么是不加锁状态,而且一次只有一个线程对其加锁。读写锁有三种状态:读模式下加锁状态,写模式下加锁状态,不加锁状态。一次只有一个线程可以占有写模式的读写锁,但是多个线程可用同时占有读模式的读写锁。读写锁也叫做共享-独占锁,当读写锁以读模式锁住时,它是共享模式锁住的,当它以写模式锁住时,它是以独占模式锁住的。


读写锁API
读写锁的数据类型为pthread_rwlock_t,如果这个类型的某个变量是静态分配的,那么可通过给它赋常值PTHREAD_RWLOCK_INITIALIZER来初始化它。
获取和释放读写锁:
都返回:成功时0,出错时为正的Exxx值
int pthread_rwlock_rdlock(pthread_rwlock_t *rwptr);
int pthread_rwlock_wrlock(pthread_rwlock_t * rwptr);
int pthread_rwlock_unlock(pthread_rwlock_t * rwptr);
int pthread_rwlock_tryrdlock(pthread_rwlock_t *rwptr);
int pthread_rwlock_trywrlock(pthread_rwlock_t *rwptr);


读写锁属性:
int pthread_rwlock_init(pthread_rwlock_t *rwptr, const pthread_rwlockattr_t *attr);
int pthread_rwlock_destroy(pthread_rwlock_t *rwptr);


int pthread_rwlockattr_init(pthread_rwlockattr_t *attr);
int pthread_rwlockattr_destroy(pthread_rwlockattr_t *attr);


int pthread_rwlockattr_getpshared(const pthread_rwlockattr_t *attr, int *valptr);
int pthread_rwlockattr_setpshared(pthread_rwlcokattr_t *attr, int *valptr);


读写锁在不同进程间共享:
PTHREAD_PROCESS_SHARED


线程取消:
通过由对方调用函数pthread_cancel,一个线程可以被同一个进程内的任何其他线程所取消( cancel )
int pthread_cancel(pthread_t tid);
为处理被取消的可能情况,任何线程可以安装(压入)和删除(弹出)清理处理程序
void pthread_cleanup_push(void(*function)(void *), void *arg);
void pthread_cleanup_pop(int execute);
这些处理程序就是发生以下情况时被调用的函数
1. 调用线程被取消(有某个线程调用pthread_cancel完成)
2. 调用线程自愿终止(或者通过调用pthread_exit,或者从自己的线程起始函数返回)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值