fcntl로 file locking하는 프로그램입니다.
글쓴이: feelpassion / 작성시간: 화, 2004/11/30 - 4:40오전
unix09A.txt라는 파일은 00 이렇게 숫자 두개만 있습니다. 하나의 프로세스는 readlock을 앞의 0에 걸어놓고 읽기만 하고, 두 번째 프로세스는 writelock을 뒤의 0에 걸어놓고 읽고, +1한 숫자를 쓰는 프로그램입니다.
이상하게도 +1한 숫자가 계속 그뒤 아무것도 없는자리에 써집니다. 그러니까 unix09A.txt파일에는 001이 남는거죠... 01만 남게 할 순 없나요? lseek()함수를 제대로 쓴 것 같은데 왜 안되는지 모르겠습니다. 프로그램을 두번 돌리면 02가 되어야겠죠....
고수님들 부탁드립니다~
//unix09A file locking program
#include <stdio.h>
#include <fcntl.h>
#include <unistd.h>
#include <stdlib.h>
int main(int argc, char ** argv)
{
int fd, retval, nread;
char buf[1];
struct flock my_lock;
if( (fd=open("unix09A.txt",O_RDWR))== -1){
perror("open()");
exit(1);
}
switch(fork()){
case -1:
perror("fork()");
exit(2);
case 0: //byte #0
my_lock.l_type = F_RDLCK;
my_lock.l_whence = SEEK_SET;
my_lock.l_start = 0;
my_lock.l_len = 1;
retval = fcntl(fd, F_SETLKW, &my_lock);
if(retval == -1){
perror("byte #0: locking");
exit(3);
}
printf("byte #0: read locked\n");
read(fd, buf, 1);
printf("byte #0: read result = %d\n", buf[0]);
sleep(3);
my_lock.l_type = F_UNLCK;
if( (fcntl(fd, F_SETLK, &my_lock))== -1){
perror("byte #0: unlocking");
exit(4);
}
printf("byte #0: unlocked\n");
exit(0);
default: //byte #1
my_lock.l_type = F_WRLCK;
my_lock.l_whence = SEEK_SET;
my_lock.l_start = 1;
my_lock.l_len = 1;
retval = fcntl(fd, F_SETLKW, &my_lock);
if( retval == -1 ){
perror("byte #1: locking");
exit(5);
}
printf("byte #1: write locked\n");
lseek(fd, SEEK_SET, 1); //읽어들일 위치를 정한다.
nread = read(fd, buf, 1);
printf("byte #1: read result = %d\n", buf[0]);
buf[0] = buf[0] + 1;
lseek(fd, SEEK_SET,1);
write(fd, buf, 1);
printf("byte #1: write result = %d\n",buf[0]);
sleep(3);
my_lock.l_type = F_UNLCK;
if( (fcntl(fd, F_SETLK, &my_lock)) == -1 ){
perror("byte #1: unlocking");
exit(6);
}
printf("byte #1: unlocked\n");
exit(0);
}
}
Forums:


먼저, lseek()의 문법이 틀렸습니다. lseek(fd, 1, SEE
먼저, lseek()의 문법이 틀렸습니다. lseek(fd, 1, SEEK_SET) 과 같은 식으로
사용하셔야 합니다. SEEK_SET은 보통 0으로 정의되어 있으므로, 올려주신
프로그램에서는 실제로 lseek(fd, 0, SEEK_CUR)를 하고 있는 셈입니다.
참고로, fork() 로 생성된 프로세스들은 open된 파일 디스크립터에 대해서 오프셋을
공유합니다. 이 프로그램에서는 우연히 영향을 받지는 않지만, 만일 parent 가 write
전에 lseek한 후, child가 한 바이트를 읽게 되면, 읽은 후 파일 디스크립터의 오프셋이
*우연히* 1로 변합니다. 만일 child가 두 바이트 이상을 읽는다면 문제가 발생합니다. 두번째 문제의 해결책으로는.. fork()후에 각각 open()을 하시면 되겠습니다.
----
Let's shut up and code.
앗 이런....쪽팔리는 일이...^^;; 죄송합니다~^^;;;;;귀찮
앗 이런....쪽팔리는 일이...^^;; 죄송합니다~^^;;;;;
귀찮아서 기억나는대로 했더만 이런 일이 생기는군요...헐~
감사합니다~
남으로 창을 내겠소.
밭이 한참갈이 괭이로 파고 호미론 김을 메지요.
구름이 꼬인다 갈리있소. 새들의 노래는 공으로 들으랴오.
강냉이가 익거든 와자셔도 좋소.
왜 사냐건 웃지요.
댓글 달기