Python中的fcntl和ioctl系统调用

要控制文件和io,我们应该使用fcntl模块。它基本上是fcntl()ioctl()Unix例程的一个接口。

此模块中的所有方法都将一个整数或io.IOBase文件描述符作为其第一个参数。

要使用此模块,我们应该使用导入它。

import fcntl

fcntl模块中有一些模块,它们是-

方法fcntl.fcntl(fd,op [,arg])

此方法用于使用文件描述符对文件执行操作。该操作由op定义。第三个参数是可选的。它可以是整数类型值或字符串类型值。当参数为整数类型时,返回值将为Cfcntl()调用的值。如果是字符串,则表示二进制结构。当此函数失败时,它将引发IOError。

方法fcntl.ioctl(fd,op [,arg [,mutate_flag]])

该方法与该方法相同fcntl(),但是在这种情况下,参数处理更为复杂。在参数中,如果传递了可变缓冲区,则其行为将取决于mutate_flag。如果为true,则缓冲区可以是可变的,否则它将充当只读缓冲区。

方法fcntl.flock(fd,op)

此方法用于使用file_descriptor对文件执行锁定操作。在某些系统上,可以使用fcntl()方法模拟此方法。

方法fcntl.lockf(fd,operation [,length [,start [,whence]]])

此方法用作锁定调用的包装器。传递operation参数以锁定或解锁文件。有不同的运算值。

  • LOCK_UN-解锁文件

  • LOCK_SH-共享锁

  • LOCK_EX-排他锁

范例程式码

import fcntl, os, time
counter_file = 'my_counter.txt'
if not os.path.exists(counter_file):
   counter_file = open('my_counter.txt', 'w')
   counter_file.write('0') #Store 0 as starting number
   counter_file.close()
for i in range(15):
   counter_file = open('my_counter.txt', 'r+')
   fcntl.flock(counter_file.fileno(), fcntl.LOCK_EX)
   count = int(counter_file.readline()) + 1
   counter_file.seek(0)
   counter_file.write(str(count))
   counter_file.close()
   print('Process ID: ' + str(os.getpid()) + ', Count: ' + str(count))
   time.sleep(0.2)

输出结果

$ python3 example.py
Process ID: 12698, Count: 1
Process ID: 12698, Count: 2
Process ID: 12698, Count: 3
Process ID: 12698, Count: 4
Process ID: 12698, Count: 5
Process ID: 12698, Count: 6
Process ID: 12698, Count: 7
Process ID: 12698, Count: 8
Process ID: 12698, Count: 9
Process ID: 12698, Count: 10
Process ID: 12698, Count: 11
Process ID: 12698, Count: 12
Process ID: 12698, Count: 13
Process ID: 12698, Count: 14
Process ID: 12698, Count: 15
$
$
$ cat my_counter.txt
15
$