先来看下面这段代码的执行:
image.png
如图中的代码所示,Python 在多线程环境下 print 的时候,由于输出显示的资源只有一个,当过多个线程想要在同一时间打印输出的时候,有的线程会因为没有抢到输出显示的资源而无法输出。
在实际的执行过程中 "Hello" 的输出次数基本都是正常的 4 次,极少的情况下出现如图中所示的 3 次。而 "the arg is" 的语句输出的次数有很大的概率不是 4 次。因为 i 是线程共享的变量,也就是说只有一个内存空间,而"Hello"字符串每个线程在执行 action 方法时会为它单独开辟一个内存空间。
还有一种情况是 print 的时候存在缓冲,但是,首先在 IDE 环境下默认是没有开启缓冲的,而且在 print 语句后调用 sys.stdout.flush(),强制立刻刷新缓冲依然没有解决异常。
期间我还以为是因为主线程退出了,导致子线程没执行到 print 程序就结束运行了。但是在 Python 中,当主线程退出之后,即使之线程没有 join, 子线程仍然会继续执