def disable_stdout_buffering():
# Appending to gc.garbage is a way to stop an object from being
# destroyed. If the old sys.stdout is ever collected, it will
# close() stdout, which is not good.
gc.garbage.append(sys.stdout)
sys.stdout = os.fdopen(sys.stdout.fileno(), 'w', 0)
# Then this will give output in the correct order:
disable_stdout_buffering()
print "hello"
subprocess.call(["echo", "bye"])
หากไม่บันทึก sys.stdout เก่า ๆ disable_stdout_buffering () ไม่ใช่ idempotent และการโทรหลายครั้งจะทำให้เกิดข้อผิดพลาดดังนี้:
Traceback (most recent call last):
File "test/buffering.py", line 17, in <module>
print "hello"
IOError: [Errno 9] Bad file descriptor
close failed: [Errno 9] Bad file descriptor
ความเป็นไปได้อีกอย่างคือ:
def disable_stdout_buffering():
fileno = sys.stdout.fileno()
temp_fd = os.dup(fileno)
sys.stdout.close()
os.dup2(temp_fd, fileno)
os.close(temp_fd)
sys.stdout = os.fdopen(fileno, "w", 0)
(การผนวกกับ gc.garbage นั้นไม่ใช่ความคิดที่ดีเพราะเป็นที่ที่วงจรไม่เป็นระเบียบและคุณอาจต้องการตรวจสอบสิ่งเหล่านั้น)