import _thread
import time
def print_time( threadName, delay):
count = 0
while count < 5:
time.sleep(delay)
count += 1
print ("%s: %s" % ( threadName, time.ctime(time.time()) ))
try:
_thread.start_new_thread( print_time, ("Thread-1", 2, ) )
_thread.start_new_thread( print_time, ("Thread-2", 4, ) )
except:
print ("Error: 无法启动线程")
while 1:
pass
多线程运行时,不会等待调用函数中的循环执行完再跳出循环往下走,而是直接返回一个值,告诉程序往下走(报错除外)。_thread.start_new_thread()创建多线程也不会进行会话阻塞,因此如果不加while 1:pass循环,则主程序会直接结束,而不理会多线程调用是否循环执行完。因此while 1: pass在实例中的作用仅仅是保证程序的存活,等待多线程函数执行。如果在while 1:函数下加入其他死循环内容,又会触发线程退让问题,导致多线程创建运行进入排队等候,也无法执行。
因此实例仅仅作为学习实例的时候使用,在正常生产环境代码中不会使用。在Python3中建议使用threading模块,其.start()启动多线程会等待线程运行直到结束,也可以通过join([time])来设置等待时间或返回代码。出现jion()后,会知道jion()的多线程函数执行结束才继续往下执行。