繁体   English   中英

等待并同时通知多个线程python

[英]Wait and notify multiple threads at the same time python

我是线程和python的新手,我想同时访问具有多个(10)http请求的服务器。 我有一个发送请求的实用程序。 我编写了如下代码:

import time
import threading

def send_req():
    start = time.time()
    response = http_lib.request(ip,port,headers,body,url)
    end = time.time()
    response_time = start - end
    print "Response Time: ", response_time

def main():
    thread_list = []
    for thread in range(10):
        t = threading.Thread(target=send_req)
        t.start()
        thread_list.append(t)

    for i in thread_list:
        i.join()

if (__name__ == "__main__"):
    main()

它运行并打印出响应时间。 但是然后,由于我是一个接一个地创建线程,因此它们的执行似乎是顺序的,而不是并发的。 我可以同时创建10个线程,然后让它们一起执行,还是一个接一个地创建线程,让创建的线程一直等待,直到它们全部创建完毕,然后同时执行它们?

您是什么意思“同时”?线程确实可以并行运行,但是您无法在相同的确切时间启动线程,因为python是一种脚本语言,它是逐行执行的。

但是,一种可能的解决方案是,您可以一个一个地启动线程,然后在线程内部,等待一些标志触发并将该标志在所有创建的线程中保持全局状态。 当该标志变为True时,您的线程将同时启动其进程。 确保在启动所有线程后触发该标志= True。 即;

def send_req():
    global flag
    while flag==False:
        pass          # stay here unless the flag gets true
    start = time.time()
    response = http_lib.request(ip,port,headers,body,url)
    end = time.time()
    response_time = start - end
    print "Response Time: ", response_time
    run_once=True

def main():
 flag=False
 thread_list = []
 for thread in range(10):
    t = threading.Thread(target=send_req)  # creating threads one by one
    #t.start()
    thread_list.append(t)

 for j in thread_list:   # now starting threads (still one by one)
    j.start()

 flag=True      # now start the working of each thread by releasing this flag from False to true     

 for i in thread_list:
    i.join()

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM