当前位置: 首页 > Linux

Linux系统编程——读写锁rwlock

时间:2023-04-06 20:11:17 Linux

读写锁是实现线程间同步的另一种方式。与互斥量类似,但读写锁将操作分为读写两种模式,读模式下多个线程可以同时占用读写锁,这使得读写锁具有更高的并行性。读写锁的特点是:写独占,读共享;写锁优先级高。对于读写锁,掌握这12个字就够了。在Linux环境下,读写锁有以下三种状态:读模式下的锁定状态(readlock)、写模式下的锁定状态(writelock)和解锁状态。读写锁虽然有读锁、写锁和无锁三种状态,但实际上它只有一种锁,而不是三种。上面说了,读写锁的特点是:写独占,读共享;写锁优先级高。具体来说:当读写锁为“lockedinwritemode”时,所有试图加锁该锁(无论是读锁还是写锁)的线程在解锁前都会被阻塞;-->writeexclusiveread-writelock当是“lockinreadmode”时,如果线程以readmode加锁,就会成功;如果线程以写模式锁定它,它将阻塞。-->当读共享读写锁为“lockedinreadmode”时,有线程试图锁在写模式,也有线程试图锁在读模式。那么读写锁会阻塞后续的读模式锁请求,写模式锁会先被满足。-->具有高优先级读写锁的写锁也称为共享排它锁。当一个读写锁在读模式下被锁定时,它在共享模式下被锁定;当它被锁定在写入模式时,它被锁定在独占模式。写独享,读共享。读写锁非常适用于对数据结构的读次数远大于写次数的情况。因为读取锁是共享的,所以这提高了并行性。主要应用函数:pthread_rwlock_init函数、pthread_rwlock_destroy函数、pthread_rwlock_rdlock函数、pthread_rwlock_wrlock函数、pthread_rwlock_tryrdlock函数、pthread_rwlock_trywrlock函数、pthread_rwlock_unlock函数。以上七个函数的返回值分别是:成功返回0,失败直接返回一个错误号。pthread_rwlock_t类型:用于定义一个读写锁变量,如:pthread_rwlock_trwlock;pthread_rwlock_init函数函数原型:intpthread_rwlock_init(pthread_rwlock_trestrictrwlock,constpthread_rwlockattr_trestrictattr);function功能:初始化一个读写锁参数说明:rwlock:传出参数,调用时要将&rwlock传给该函数;attr:表示读写锁属性,一般传NULL,表示使用默认属性;pthread_rwlock_destroy函数函数原型:intpthread_rwlock_destroy(pthread_rwlock_t*rwlock);锁定pthread_rwlock_rdlock函数函数原型:intpthread_rwlock_rdlock(pthread_rwlock_t*rwlock);function功能:在读模式下请求读写锁。(常简写为:请求读锁)pthread_rwlock_wrlock函数函数原型:intpthread_rwlock_wrlock(pthread_rwlock_t*rwlock);function功能:通过写入请求读写锁。(常简写为:请求写锁)pthread_rwlock_unlock函数函数原型:intpthread_rwlock_unlock(pthread_rwlock_t*rwlock);函数功能:解锁。pthread_rwlock_tryrdlock函数函数原型:intpthread_rwlock_tryrdlock(pthread_rwlock_t*rwlock);函数作用:读模式下非阻塞请求读写锁(非阻塞请求读锁)pthread_rwlock_trywrlock函数函数原型:intpthread_rwlock_trywrlock(pthread_rwlock_t*rwlock);函数作用:非阻塞通过写请求一个读写锁(非阻塞请求写锁)/*3个线程定时“写”全局资源,5个线程定时“读”同一个全局资源time*/#include#include#includeint计数器;//全局资源pthread_rwlock_trwlock;void*th_write(void*arg){intt;inti=(int)arg;while(1){t=计数器;睡眠(1000);pthread_rwlock_wrlock(&rwlock);printf("=======write%d:%lu:counter=%d++counter=%d\n",i,pthread_self(),t,++counter);pthread_rwlock_unlock(&rwlock);睡眠(5000);}returnNULL;}void*th_read(void*arg){inti=(int)arg;while(1){pthread_rwlock_rdlock(&rwlock);printf("---------------------------读取%d:%lu:%d\n",i,pthread_self(),柜台);线程d_rwlock_unlock(&rwlock);睡着了(900);}returnNULL;}intmain(void){inti;pthread_ttid[8];pthread_rwlock_init(&rwlock,NULL);for(i=0;i<3;i++)pthread_create(&tid[i],NULL,th_write,(void*)i);对于(i=0;i<5;i++)pthread_create(&tid[i+3],NULL,th_read,(void*)i);对于(i=0;i<8;i++)pthread_join(tid[i],NULL);pthread_rwlock_destroy(&rwlock);//释放读写锁return0;}更多精彩内容请关注公众号良旭Linux,在公众号回复1024免费获得5T技术资料,包括:Linux、C/C++、Python、RaspberryPi、嵌入式、Java、人工智能等交流群。最后,最近有很多朋友找我要一份Linux学习路线图,所以我结合自己的经验,利用业余时间熬夜一个月,整理了一本电子书。无论你是面试还是自我提升,相信都会对你有所帮助!免费送给大家,只求大家给我点个赞!电子书|LinuxDevelopmentLearningRoadmap也希望有小伙伴可以加入我的行列,把这本电子书做得更加完美!获得?希望老铁们来个三连击,让更多人看到这篇文章。推荐阅读:干货|程序员和高级架构师免费发送工件的必备资源|支持搜索的资源网站