pthread中提供的锁有:pthread_mutex_t, pthread_spinlock_t, pthread_rwlock_t。
pthread_mutex_t是互斥锁,同一瞬间只能有一个线程能够获取锁,其他线程在等待获取锁的时候会进入休眠状态。因此pthread_mutex_t消耗的CPU资源很小,但是性能不高,因为会引起线程切换。
pthread_spinlock_t是自旋锁,同一瞬间也只能有一个线程能够获取锁,不同的是,其他线程在等待获取锁的过程中并不进入睡眠状态,而是在CPU上进入“自旋”等待。自旋锁的性能很高,但是只适合对很小的代码段加锁(或短期持有的锁),自旋锁对CPU的占用相对较高。
pthread_mutex_t是互斥锁,同一瞬间只能有一个线程能够获取锁,其他线程在等待获取锁的时候会进入休眠状态。因此pthread_mutex_t消耗的CPU资源很小,但是性能不高,因为会引起线程切换。
pthread_spinlock_t是自旋锁,同一瞬间也只能有一个线程能够获取锁,不同的是,其他线程在等待获取锁的过程中并不进入睡眠状态,而是在CPU上进入“自旋”等待。自旋锁的性能很高,但是只适合对很小的代码段加锁(或短期持有的锁),自旋锁对CPU的占用相对较高。

本文对比了pthread库中的pthread_mutex_t、pthread_spinlock_t和pthread_rwlock_t与TBB库中的mutex、recursive_mutex、spin_mutex、queuing_mutex、spin_rw_mutex和queuing_rw_mutex在多线程环境下的性能。测试显示,pthread_rwlock_t在多线程读操作中优于pthread_mutex_t,而tbb::spin_rw_mutex在读写操作中表现最佳。在自旋锁方面,pthread_spinlock_t比tbb::spin_mutex性能高28%。

571

被折叠的 条评论
为什么被折叠?



