转载请注明出处:http://blog.csdn.net/cywosp/article/details/30083015
1. 从文件里读取序号。2. 使用这个序号完毕应用程序定义的任务。3. 递增这个序号并将其写回文件里。
为了防止出现这样的情况,Linux提供了flock(对整个文件加锁)、fcntl(对整个文件区域加锁)两个函数来做进程间的文件同步。同一时候也可以使用信号量来完毕所需的同步。但通常使用文件锁会更好一些。由于内核可以自己主动将锁与文件关联起来。
#include <sys/file.h>
// Returns 0 on success, or -1 on errorint flock (intfd, int operation);
operation能够赋例如以下值:
下图是进程A先设置了锁,进程B后设置锁的支持情况:
在实际操作过程中,參数operation能够指定相应的值将共享锁转换成相互排斥锁(反之亦然)。
将一个共享锁转换成相互排斥锁,假设还有一个进程要获取该文件的共享锁则会堵塞。除非operation參数指定了LOCK_NB标记,即:(LOCK_SH | LOCK_NB)。锁的转换过程不是一个原子操作。在转换的过程中首先会删除既有的锁,然后创建新锁。
此外。锁会在对应的文件描写叙述符被关闭之后自己主动释放。
同一时候,当一个文件描写叙述符被复制时(dup()、dup2()、或一个fcntl() F_DUPFD操作),新的文件描写叙述符会引用同一个文件锁。
flock(fd, LOCK_EX);new_fd = dup(fd);flock(new_fd, LOCK_UN);
从而我们能够得知新的文件描写叙述符指向了同一个锁。所以,假设通过一个特定的文件描写叙述符获取了一个锁而且创建了该描写叙述符的一个或多个副本,那么,假设不显示的调用一个解锁操作,仅仅有当文件描写叙述符副本都被关闭了之后锁才会被释放。
flock (fd, LOCK_EX);if (0 == fork ()) {flock (fd, LOCK_UN);}
通过fork()创建的锁在exec()中会得以保留(除非在文件描写叙述符上设置了close-on-exec标记而且该文件描写叙述符是最后一个引用底层的打开文件描写叙述的描写叙述符)。
fd1 = open ("test.txt", O_RDWD);fd2 = open ("test.txt", O_RDWD);flock (fd1, LOCK_EX);flock (fd2, LOCK_EX);
- 仅仅能对整个文件进行加锁。这样的粗粒度的加锁会限制协作进程间的并发。假如存在多个进程,当中各个进程都想同一时候訪问同一个文件的不同部分。
- 通过flock()仅仅能放置劝告式锁。
- 非常多NFS实现不识别flock()放置的锁。
版权声明:本文博客原创文章,博客,未经同意,不得转载。
本文转自mfrbuaa博客园博客,原文链接:http://www.cnblogs.com/mfrbuaa/p/4748797.html,如需转载请自行联系原作者