【原文】

需求:打印一颗 ”*” 休息1s

代码如下:

#!/usr/bin/python
#coding=utf-8
'''
暂停1s输出
''' import time def printStar(n):
for i in range(n):
print " * ",
time.sleep(1) if __name__ == '__main__':
printStar(10)

输出结果(等待10s后一次性输出):

[root@miner_k test]# python sleep.py
* * * * * * * * * *

分析原因: 
在运行代码时,打印10个"*"没有占满缓存区,所以等到程序结束时,才会一次性输出。

缓冲区的刷新方式:
1.flush()刷新缓存区
2.缓冲区满时,自动刷新
3.文件关闭或者是程序结束自动刷新。

正确代码:

#!/usr/bin/python
#coding=utf-8
'''
暂停1s输出
''' import time
import sys def printStar(n):
for i in range(n):
print " * ",
sys.stdout.flush()
time.sleep(1) if __name__ == '__main__':
printStar(10)

另外,在https://blog.csdn.net/qq_16234613/article/details/79532050  中也有相关描述:

【实际测试】

Python 3 应该不存在此前置刷新缓冲区 现象。

#!/usr/bin/python
#coding=utf-8 #暂停1s输出 import time def printStar(n):
for i in range(n):
print("*"),
time.sleep(1) if __name__ == '__main__':
printStar(60)

对于Python3环境,将代码作小的修改后,实际打印的效果为:

每个1s打印一次  *

可通过 计时程序执行时间:

#!/usr/bin/python
#coding=utf-8 #暂停1s输出 import time def printStar(n):
for i in range(n):
print("*"),
time.sleep(1)
start = time.clock()
print("Timing from now on.") #从现在开始计时
if __name__ == '__main__': printStar(60) end = time.clock()
t=end-start
print("Rumtime is :",t,"s")

————————(我是分割线)————————

参考:

1. https://blog.csdn.net/miner_k/article/details/76946045

2. https://blog.csdn.net/qq_16234613/article/details/79532050

备注:

初次编辑时间:2019年9月22日17:21:47

环境:Windows 7   / Python 3.7.2

最新文章

  1. PowerShell实现批量重命名文件
  2. ExtJS6 TreePanel树节点合上展开显示不同图标
  3. MySQL数据库集群进行正确配置步骤
  4. 收集的maven 仓库地址(maven repository)
  5. 关于jquery html()方法获取带有OBJECT标签的元素内容时,出现“类型不匹配。”的解决办法
  6. 锋利的jquery-选择器
  7. Visual Studio Code扩展
  8. C# div布局
  9. 学习linux之vi编辑器
  10. VS中C++对象的内存布局
  11. C++ 模板基础
  12. wget下载阿里云RDS备份集
  13. Android开发(十六)——Android listview onItemClick事件失效的原因
  14. 源码编译安装libtool工具
  15. ui-router ng-router
  16. Unity3D协同函数与异步加载功能实战 学习
  17. 使用Dotfuscator混淆你的.net程序
  18. 堆 C语言实现
  19. 002-and design-dva.js 知识导图-01JavaScript 语言,React Component
  20. TensorFlow实现FM

热门文章

  1. 灰度图像--图像分割 阈值处理之OTSU阈值
  2. vue项目中主要文件的加载顺序(index.html、main.js、App.vue)
  3. IP输出 之 ip_local_out
  4. linux中~和/,$和#的区别
  5. Ubuntu——配置JDK
  6. c 使用lua 示例
  7. https知识汇总
  8. 在win10系统安装两个不同版本的mySQL数据库
  9. Android——NativeActivity - C/C++ Apk开发
  10. Enetity Framework 加载关联数据后,循环问题