方法锁
文件仅仅是充当一个指示器的角色,程序间需要通过相互协作来使用它们。锁文件只是建议性锁,与此对立的是强制性锁。为创建一个用作指示器的文件,我们使用带O_CREATE和O_EXCL标志的open系统调用。这将使我们以一个原子
*** 作同时完成两项工作:确定文件不存在,然后创建它。实现//file : lock.c#i nclude#i nclude#i nclude#i nclude#i ncludeint main(){int file_descint save_errnofile_desc = open(/tmp/LockFile.test, O_RDWR O_CREAT O_EXCL, 0444)if (file_desc <0){save_errno = errnoprintf(Open failed with error is %dn, save_errno)}else {printf(Open succeededn)}exit(EXIT_SUCCESS)}第一次运行程序:$ lock输出如下:Open succeeded我们再次运行程序:$ lock输出如下:Open failed with error is 17分析:第一次运行程序时,由于文件并不存在,所以执行成功。对于后续的执行,因为文件已经存在而失败了。若想程序再次执行成功,必须删除锁文件。在Linux系统中,通常错误号码17代表的是EEXIST,此错误用以表示一个文件已存在。错误号定义在头文件errno.h或(更常见的)它所包含的头文件中。前面的这5个基本函数实现了文件的打开、读写等基本 *** 作,这一节将讨论的是,在文 件已经共享的情况下如何 *** 作,也就是当多个用户共同使用、 *** 作一个文件的情况,这时,Linux 通常采用的方法是给文件
上锁,来避免共享的资源产生竞争的状态。
文件锁包括建议性锁和强制性锁。
建议性锁要求每个上锁文件的进程都要检查是否有锁存,并且尊重已有的锁。在一般情况下,内核和系统都不使用建议性锁。强制性锁是由内 核执行的锁,当一个文件被上锁进行写入 *** 作的时候,内核将阻止其他任何文件对其进行读写 *** 作。采用强制性锁对性能的影响很大,每次读写 *** 作都必须检查是否有锁存在。
在 Linux 中,实现文件上锁的函数有lock和fcntl,其中flock用于对文件施加建议性锁,而fcntl不仅可以施加建议性锁,还可以施加强制锁。同时,fcntl还能对文件的某一记录进行上锁,也就是记录锁。
记录锁又可分为读取锁和写入锁,其中读取锁又称为共享锁,它能够使多个进程都能在文件的同一部分建立读取锁。而写入锁又称为排斥锁,在任何时刻只能有一个进程在文件的某个部分上建立写入锁。当然,在文件的同一部分不能同时建立读取锁和写入锁。
评论列表(0条)