ockf(fd,1,0)是给fd文件上锁,lockf(fd,0,0)是解锁,配合使用,实现进程的互斥。
头文件
#include <sys/file.h>
函数:
int lockf(int fd, int cmd, off_t len)
fd -- 文件id.
fcntl(2)的接口(inteface)函数
返回1表示调用lockf成功.
lockf用于锁定或打开锁定一个共享文件.
*** 作有:
F_LOCK(锁定),F_TLOCK,F_ULOCK(打开锁定),F_TEST
扩展资料:注意事项
lockf()函数允许将文件区域用作信号量(监视锁),或用于控制对锁定进程的访问(强制模式记录锁定)。试图访问已锁定资源的其他进程将返回错误或进入休眠状态,直到资源解除锁定为止。当关闭文件时,将释放进程的所有锁定,即使进程仍然有打开的文件。当进程终止时,将释放进程保留的所有锁定。
函数声明:
/* 'lockf' is a simpler interface to the locking facilities of 'fcntl'. LEN is always relative to the current file position. The CMD argument is one of the following. This function is a cancellation point and therefore not marked with __THROW. */
#include <unistd.h>
int lockf(int fd, int cmd, off_t len)
前面的这5个基本函数实现了文件的打开、读写等基本 *** 作,这一节将讨论的是,在文 件已经共享的情况下如何 *** 作,也就是当多个用户共同使用、 *** 作一个文件的情况,这时,Linux 通常采用的方法是给文件上锁,来避免共享的资源产生竞争的状态。文件锁包括建议性锁和强制性锁。
建议性锁要求每个上锁文件的进程都要检查是否有锁存,并且尊重已有的锁。在一般情况下,内核和系统都不使用建议性锁。强制性锁是由内 核执行的锁,当一个文件被上锁进行写入 *** 作的时候,内核将阻止其他任何文件对其进行读写 *** 作。采用强制性锁对性能的影响很大,每次读写 *** 作都必须检查是否有锁存在。
在 Linux 中,实现文件上锁的函数有lock和fcntl,其中flock用于对文件施加建议性锁,而fcntl不仅可以施加建议性锁,还可以施加强制锁。同时,fcntl还能对文件的某一记录进行上锁,也就是记录锁。
记录锁又可分为读取锁和写入锁,其中读取锁又称为共享锁,它能够使多个进程都能在文件的同一部分建立读取锁。而写入锁又称为排斥锁,在任何时刻只能有一个进程在文件的某个部分上建立写入锁。当然,在文件的同一部分不能同时建立读取锁和写入锁。
你写错了#include <stdio.h>
#include <stdlib.h>
#include<unistd.h>
#include<sys/types.h>
#include <fcntl.h>
int main(void)
{
int fd1=0,fd2=0
int output
output=open("/root/647.txt", O_CREAT|O_WRONLY, S_IRUSR|S_IWUSR)
if( (fd1=fork() )==0)
{
lockf(output, 1, 0)
write(output,"fd1\n",4)
sleep(2)
write(output,"fd1\n",4)
lockf(output, 0, 0)
}
else if( (fd2=fork() )==0)
{
lockf(output, 1, 0)
write(output,"fd2\n",4)
sleep(2)
write(output,"fd2\n",4)
lockf(output, 0, 0)
}
else
{
lockf(output, 1, 0)
write(output,"fd\n",3)
sleep(2)
write(output,"fd\n",3)
lockf(output, 0, 0)
}
return 0
}
结果为
fd
fd
fd2
fd2
fd1
fd1
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)