1

我先解锁然后关闭。一个过程附加记录 ABCDEFGHIJ。另一个进程读取同一个文件并写入 ZZZZ。普通文件应该是 ZZZZ ABCDEFGHIJ

但只有一次我看到了以下内容: ZZZZEFGHIJ 所以记录 ABCDEFGHIJ 被 ZZZZ 损坏了。

看来我的锁定不起作用。但我测试了它。一个进程真的在等待另一个进程。另一个进程可以在打开和锁定之间写入文件吗?还是在解锁和关闭之间?

代码如下

int MyOpenWrite(char *name,int flags) {
int fd
fd = open(name,flags,S_IREAD|S_IWRITE|S_IRGRP|S_IWGRP|S_IROTH|S_IWOTH);
LockFile(fd);
return fd;
 }

int WriteFile(char *name, char *data) {
...
fd = MyOpenWrite(fullName,O_CREAT|O_WRONLY|O_TRUNC);
write(fd,data,strlen(data));
UnLockFile(fd);
close(fd);
}

int ReadFile(char *name, char *data, int maxLength) {
fd = open(name,O_RDONLY);
LockFile(fd);
...
UnLockFile(fd);
close(fd);
}

int AppendFile(char *name, char *data) {
fd = MyOpenWrite(fullName,O_WRONLY|O_APPEND);
...
len=write(fd,data,strlen(data));
UnLockFile(fd);
close(fd);
 }

int LockFile(int fd) {
struct flock    lock;
lock.l_type = F_WRLCK;
lock.l_start = 0;
lock.l_whence = SEEK_SET;
lock.l_len = 0;
return fcntl(fd,F_SETLKW,&lock);
}

int UnLockFile(int fd)  {
struct flock    lock;
lock.l_type = F_UNLCK;
lock.l_start = 0;
lock.l_whence = SEEK_SET;
lock.l_len = 0;
return fcntl(fd,F_SETLKW,&lock);
}

我尝试关闭(fd)UnLock(fd)。它似乎有效。但是无论如何,打开和锁定之间存在延迟。谢谢。

4

1 回答 1

3

只要您不write(2)打开文件(解锁后),您先解锁还是先解锁都没关系close(2)

但是,close(2)-ing 文件会解锁它(至少在没有其他进程共享相同打开的文件描述符的情况下)。

fcntl(2)

As well as being removed by an explicit F_UNLCK, record locks are
automatically released when the process terminates or if it closes any
file descriptor referring to a file on which locks are held.

附录:应该检查失败

请注意,您的代码缺少错误检查。几乎每个库函数或系统调用,特别是fcntl, readwrite都可能失败(并设置errno为由例如显示perrorstrerror(errno)在某些日志或打印中显示)。您不会fcntlLockFileorUnlockFile函数中检查成功或失败,也不会在调用者中检查。

于 2013-03-19T01:43:11.710 回答