Per справочная страница Solaris 10 fcntl()
:
Все блокировки, связанные с файлом для данного процесса, удаляются, когда дескриптор файла для этого файла закрываетсяэтот процесс
Выполнение команды truss -f -a -vall -l -d -o tout nano test.c
приводит к следующим строкам в выводе фермы:
Base time stamp: 1527722170.2660 [ Wed May 30 19:16:10 EDT 2018 ]
6621/1: 0.0000 execve("/usr/bin/nano", 0xFEFFEADC, 0xFEFFEAE8) argc = 2
6621/1: argv: nano test.c
...
6621/1: 0.0417 open64("/home/achenle/junk/test.c", O_RDONLY) = 3
6621/1: 0.0418 fcntl(3, F_GETFD, 0xFEFFEA98) = 0
6621/1: 0.0422 fstat64(3, 0xFEFFE6A0) = 0
6621/1: d=0x045D0009 i=418292 m=0100644 l=1 u=1000 g=100 sz=708
6621/1: at = May 30 19:09:05 EDT 2018 [ 1527721745.204432507 ]
6621/1: mt = May 30 19:04:25 EDT 2018 [ 1527721465.715445770 ]
6621/1: ct = May 30 19:04:25 EDT 2018 [ 1527721465.833365263 ]
6621/1: bsz=1024 blks=3 fs=lofs
6621/1: 0.0424 fstat64(3, 0xFEFFE5B0) = 0
6621/1: d=0x045D0009 i=418292 m=0100644 l=1 u=1000 g=100 sz=708
6621/1: at = May 30 19:09:05 EDT 2018 [ 1527721745.204432507 ]
6621/1: mt = May 30 19:04:25 EDT 2018 [ 1527721465.715445770 ]
6621/1: ct = May 30 19:04:25 EDT 2018 [ 1527721465.833365263 ]
6621/1: bsz=1024 blks=3 fs=lofs
6621/1: 0.0425 ioctl(3, TCGETA, 0xFEFFE650) Err#25 ENOTTY
6621/1: 0.0426 read(3, " # i n c l u d e < s y".., 1024) = 708
6621/1: 0.0428 read(3, 0x0814D794, 1024) = 0
6621/1: 0.0428 llseek(3, 0, SEEK_CUR) = 708
6621/1: 0.0429 close(3) = 0
Этот окончательный close(3)
снимает все блокировки файла.И обратите внимание, что это происходит менее чем за 5/100 секунды после запуска nano
.