python linux下运行无输出的真相竟是flush()

在Linux环境下,Python程序print输出可能不会立即显示,原因是输出被缓存。通过调用sys.stdout.flush()可强制flush缓冲区到文件。Windows系统下则没有此现象。本文探讨了print的缓冲机制,以及在Python2和3中print的差异,特别是flush参数的影响。
部署运行你感兴趣的模型镜像

上次的crontab输出问题,抱歉了,我想错了。
原文:http://blog.csdn.net/sinat_21302587/article/details/62221648

本以为是 crontab 的问题,其实是 python 的问题。好了,听我细细道来。

环境: linux

代码:

import time
import sys

for i in range(5):
    print i,
    sys.stdout.flush()
    time.sleep(1)

将以上代码在linux 中运行,在程序执行过程中,依次输出0,1,2,3,4

将 sys.stdout.flush() 注释掉,在程序执行完毕后,一次性输出0,1,2,3,4

为什么?

原因是python 的print 先写到缓冲区了,还没flush到文件。
于是加了一行“ sys.stdout.flush()” –在每次print后都flush一次。

获取python的print流,所有的print流在shell中都是一次性获取的,这种情况对于执行时间比较短的程序脚本没什么影响,但是当python程序需要执行很长时间,而需要通过print流追踪程序,就影响比较大。

通过查阅资料,可知:
当我们在 Python 中打印对象调用 print obj 时候,事实上是调用了 sys.stdout.write(obj+’\n’)
print 将你需要的内容打印到了控制台,然后追加了一个换行符
print 会调用 sys.stdout 的 write 方法 .

windows 没出现这种情况,都是依次输出。平台差异,具体原因待深入研究。
抛砖

将上述代码中的ptint i,的逗号去掉这显示的有些不同,去掉逗号后,会在运行过程中直接依次输出0,1,2,3,4 无论是否flush()

这是什么情况呢?

首先明确下,print 在python2 中是一个关键字同时也是一个函数,即在使用过程中无论加还是不加括号都不会有影响。
而在python3 中 print 只是一个函数,所以必须要加入括号。

python3 print 函数原型:
print(*objects, sep=’ ‘, end=’\n’, file=sys.stdout, flush=False)

可带的参数中,包括了flush(新加入的)
同时注意end默认的是换行。这里似乎可以解释,在python2 中如果print 后面不加逗号,则默认以换行结束的话,可能会触发flush()。
而加逗号后,print 语句不以换行符结束,设定的flush()才为起效。

解释的未必准确,欢迎探讨。

参考资料

[1].https://zhidao.baidu.com/question/575650032.html
[2].markdown 字体颜色 http://blog.csdn.net/testcs_dn/article/details/45719357/
[3].python3 print() 用法 http://blog.csdn.net/chr1991/article/details/51013308

您可能感兴趣的与本文相关的镜像

Python3.9

Python3.9

Conda
Python

Python 是一种高级、解释型、通用的编程语言,以其简洁易读的语法而闻名,适用于广泛的应用,包括Web开发、数据分析、人工智能和自动化脚本

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值