Python 的 file.write 是原子的吗?
Is Python's file.write atomic?
file.write
操作在 Python 或 C 中是原子的吗?
例子
考虑以下两个线程
线程 1
with open('foo', 'a') as f:
f.write('123456')
线程 2
with open('foo', 'a') as f:
f.write('abcdef')
我们能保证不会得到像下面这样的混合文本吗?
1a2b3c4d5e6f
or
123abc456def
而是得到两个可能的正确结果之一
123456abcdef
abcdef123456
请注意,每个线程中只有一次写入调用,显然原子多次写入需要某种锁。我也知道基于文件的锁。这个问题的理想答案是 yes/no 和 evidence/documentation.
看起来底层 OS write() 调用甚至可能不是原子的:
Atomicity of `write(2)` to a local filesystem
file.write
操作在 Python 或 C 中是原子的吗?
例子
考虑以下两个线程
线程 1
with open('foo', 'a') as f:
f.write('123456')
线程 2
with open('foo', 'a') as f:
f.write('abcdef')
我们能保证不会得到像下面这样的混合文本吗?
1a2b3c4d5e6f
or
123abc456def
而是得到两个可能的正确结果之一
123456abcdef
abcdef123456
请注意,每个线程中只有一次写入调用,显然原子多次写入需要某种锁。我也知道基于文件的锁。这个问题的理想答案是 yes/no 和 evidence/documentation.
看起来底层 OS write() 调用甚至可能不是原子的:
Atomicity of `write(2)` to a local filesystem