您的位置:首页 > 运维架构 > Linux

进程与线程的各种锁分析总结

2017-02-02 01:04 204 查看
进程的文件读写锁学习:http://blog.csdn.net/anonymalias/article/details/9197641
http://blog.chinaunix.net/uid-27177626-id-3791049.html
线程的读写锁学习:http://blog.csdn.net/callinglove/article/details/46646369

至于进程和线程的mutex锁在我前篇文章就有http://blog.csdn.net/jason_zjj/article/details/54731334

另外附上linux中mmap的共享内存用法http://blog.csdn.net/angelbosj/article/details/8272887

经过github的test_lock文件里的四个程序测试,

得到了一些结论:

对于线程的mutex锁,效率比线程的读写锁(rwlock)要高,但是没有读写锁实用性强,因为读写锁可以有共享读锁。

对于进程的mutex锁,效率比文件读写锁的效率要高的非常多,文件锁效率虽然非常慢,但是比较安全,在一个进程挂掉之后,如果它获取了mutex锁。则其他进程会阻塞,但是如果用了文件锁,则会自动释放该锁。

然后线程的mutex是比进程的mutex效率高的。。毕竟线程比较轻量级。

前篇文章对线程和进程的mutex锁的使用已经分析的比较详细。

对于文件锁的话,其实也叫记录锁,可以对文件的部分字节范围的数据进行上锁。这样就可以实现用一个文件,供给多个进程同时上锁(不同位置的锁)。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息