我试图在 linux 下使用 Python 来理解 FIFO,但我发现了一个我不理解的奇怪行为。
以下是fifoserver.py
import sys
import time
def readline(f):
s = f.readline()
while s == "":
time.sleep(0.0001)
s = f.readline()
return s
while True:
f = open(sys.argv[1], "r")
x = float(readline(f))
g = open(sys.argv[2], "w")
g.write(str(x**2) + "\n")
g.close()
f.close()
sys.stdout.write("Processed " + repr(x) + "\n")
这是fifoclient.py
import sys
import time
def readline(f):
s = f.readline()
while s == "":
time.sleep(0.0001)
s = f.readline()
return s
def req(x):
f = open("input", "w")
f.write(str(x) + "\n")
f.flush()
g = open("output", "r")
result = float(readline(g))
g.close()
f.close()
return result
for i in range(100000):
sys.stdout.write("%i, %s\n" % (i, i*i == req(i)))
mkfifo input
我还使用和创建了两个 FIFO mkfifo output
。
我不明白的是,为什么当我在一些请求后从两个控制台运行服务器(with python fifoserver.py input output
)和客户端(with )时,客户端崩溃并出现“断管”错误。请注意,在崩溃之前,我已经看到数百到数千个正确处理的请求运行良好。python fifoclient.py
f.flush()
我的代码有什么问题?