python运行时强制刷新缓冲区

发布时间:2019-09-04 06:48:11编辑:auto阅读(1827)

    需求:打印一颗”*”休息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)
    

关键字