进程的文件读写锁学习:http://blog.youkuaiyun.com/anonymalias/article/details/9197641
http://blog.chinaunix.net/uid-27177626-id-3791049.html
线程的读写锁学习:http://blog.youkuaiyun.com/callinglove/article/details/46646369
至于进程和线程的mutex锁在我前篇文章就有http://blog.youkuaiyun.com/jason_zjj/article/details/54731334
另外附上linux中mmap的共享内存用法http://blog.youkuaiyun.com/angelbosj/article/details/8272887
经过github的test_lock文件里的四个程序测试,
得到了一些结论:
对于线程的mutex锁,效率比线程的读写锁(rwlock)要高,但是没有读写锁实用性强,因为读写锁可以有共享读锁。
对于进程的mutex锁,效率比文件读写锁的效率要高的非常多,文件锁效率虽然非常慢,但是比较安全,在一个进程挂掉之后,如果它获取了mutex锁。则其他进程会阻塞,但是如果用了文件锁,则会自动释放该锁。
然后线程的mutex是比进程的mutex效率高的。。毕竟线程比较轻量级。
前篇文章对线程和进程的mutex锁的使用已经分析的比较详细。
对于文件锁的话,其实也叫记录锁,可以对文件的部分字节范围的数据进行上锁。这样就可以实现用一个文件,供给多个进程同时上锁(不同位置的锁)。
本文探讨了进程和线程的锁机制,包括mutex锁、读写锁及文件锁等,并对比了它们之间的效率和实用性差异。通过实验得出,线程mutex锁效率高于rwlock,而进程mutex锁比文件锁效率更高。

2299

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



