锁 (读写锁优先级 写饥饿) (锁竞争引发的高系统调用)
(读写锁优先级 写饥饿):
对一个同享的数据布局,读的频率远弘远于写,所以用了读写锁.但是发现写线程老是抢不到锁.
按The Open Group 的Single UNIX? Specification所说,"Thepthread_rwlock_rdlock() function applies a read lock to the read-write lock referenced by rwlock. The calling thread acquires the read lock if a writer does not hold the lock and there are no writers blocked on the lock. It is unspecified whether the calling thread acquires the lock when a writer does not hold the lock and there are writers waiting for the lock" 貌似意思是说,没有writer在持有写锁的时,reader是可以拿到读锁的。然则没有划定,若是有writer在等写锁,该若何?
自己测试结果:
对于ACE_RW_Mutex,当几个线程不断获取释放读锁,各读线程使用锁的时间叠加,锁讲一直处于被读取状态,此时加写锁,写线程将一直处于等待状态。
即ACE_RW_Mutex 并不保证读写锁请求和处理时序。读锁获条件是只要当前锁没有被别人以写方式获取就可以获取到读权限。
这样做的优势是由于读锁可并发执行,提高CPU利用率。缺点是在读锁使用频度较高情况下,会出现不断有线程使用读锁,写锁线程饥饿等待。
pthread_rwlockattr_setkind_np 应该可以调整读写锁优先级顺序。
示例如下:
pthread_rwlockattr_t attr;
pthread_rwlockattr_init(&attr);
pthread_rwlockattr_setkind_np (&attr, PTHREAD_RWLOCK_PREFER_WRITER_NONRECURSIVE_NP);
(void)pthread_rwlock_init(&rwlock, &attr);
(锁竞争引发的高系统调用):
遇到一个场景,多线程情况下出现了超高频的读写锁的读锁访问,然后就发现该场景下内核态CPU很高,感觉很可能与读写锁实现机制有关,读锁的成功申请同样会触发内核态调用,比如使用到了内核态的锁实现了读写锁。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
2014-08-23 极路由体验