为什么time.sleep()延迟在嵌套的while循环中没有按预期工作?

时间:2017-03-26 17:45:08

标签: python c gcc delay sleep

有人可以解释为什么以下代码(打印乘法表)无法正常工作

import time
n = int(input("Enter number of multiples: "))
k = int(input("Enter number of tables: "))
c = 1
m = 1 #multiple
while m <= n:
    while c <= k:
        print("%4d" % (c*m), end='')
        c+=1
        time.sleep(1) #slower behaviour
    m+=1
    c=1
    print("")

这有什么奇怪之处在于,它不是以一秒的间隔打印单个水平元素,而是以“k”的间隔一次打印整行。秒。

事实上,用C编写的代码表现出相同的行为。

#include<stdio.h>
#include<unistd.h>
void main(){
    int n,k,c=1,m=1;
    printf("Enter number of Multiples: ");
    scanf("%d",&n);
    printf("Enter number of tables: ");
    scanf("%d",&k);
    while(m<=n){
        while(c<=k){
            printf("%4d",(c*m));
            c+=1;
            //sleep(1); //slower here
        }
        m+=1;
        c=1;
        sleep(1); //faster here
        printf("\n");
    }
}

也就是说,它不是打印元素而是等待一秒钟,而是以“k”的间隔一次打印整行。第二(或多个)。

1 个答案:

答案 0 :(得分:5)

你告诉print跳过换行符但终端输出是行缓冲的。您需要刷新数据。

print("%4d" % (c*m), end='', flush=True)