PHP前端开发

Python线程重复执行问题: 为什么程序执行结束时打印了多个“Thread-5”,却只有一个线程真正执行了?

百变鹏仔 5天前 #Python
文章标签 线程

python线程重复执行

问题:

为什么程序执行结束时打印了多个“thread-5”,看起来线程5重复执行了?去掉sub()函数中的time.sleep(1)后,为什么程序又可以正常执行,每个线程按顺序执行?

回答:

立即学习“Python免费学习笔记(深入)”;

程序中重复执行sub()函数的线程是线程5的原因在于:

去除time.sleep(1)后,程序可以正常运行,每个线程按顺序执行,原因如下:

正确的程序代码:

import threading, timenum = 5lock = threading.Lock()     # 创建同步锁# L = []def sub():    global num    print('sub %s' % t.name)    lock.acquire()      # 获得同步锁:不让别的线程在同一时刻运行    print(threading.current_thread().getName())    temp = num    # time.sleep(1)    num = temp - 1    lock.release()      #解除同步锁    print('%s ' % t.name, num)for i in range(5):    t = threading.Thread(target=sub)    t.start()    print('start %s' % t.name)    # L.append(t)# for T in L:#     T.join()print('s', num)

此代码确保每个线程按顺序打印其名称和更新的num值。