日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程语言 > python >内容正文

python

为什么不能用python_为什么我不能用python加入这个线程?

發(fā)布時(shí)間:2023/12/20 python 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 为什么不能用python_为什么我不能用python加入这个线程? 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

我正在寫一個(gè)多線程類。該類有一個(gè)parallel_process()函數(shù),該函數(shù)被并行任務(wù)重寫。要處理的數(shù)據(jù)放入queue。每個(gè)線程中的worker()函數(shù)一直調(diào)用parallel_process(),直到queue為空。結(jié)果放入results隊(duì)列對(duì)象中。類定義是:import threading

try:

from Queue import Queue

except ImportError:

from queue import Queue

class Parallel:

def __init__(self, pkgs, common=None, nthreads=1):

self.nthreads = nthreads

self.threads = []

self.queue = Queue()

self.results = Queue()

self.common = common

for pkg in pkgs:

self.queue.put(pkg)

def parallel_process(self, pkg, common):

pass

def worker(self):

while not self.queue.empty():

pkg = self.queue.get()

self.results.put(self.parallel_process(pkg, self.common))

self.queue.task_done()

return

def start(self):

for i in range(self.nthreads):

t = threading.Thread(target=self.worker)

t.daemon = False

t.start()

self.threads.append(t)

def wait_for_threads(self):

print('Waiting on queue to empty...')

self.queue.join()

print('Queue processed. Joining threads...')

for t in self.threads:

t.join()

print('...Thread joined.')

def get_results(self):

results = []

print('Obtaining results...')

while not self.results.empty():

results.append(self.results.get())

return results

我用它來(lái)創(chuàng)建一個(gè)并行任務(wù):

^{pr2}$

但是,并不是每次代碼運(yùn)行時(shí)所有線程都加入。有時(shí)只有2個(gè)連接,有時(shí)沒(méi)有線程連接。我不認(rèn)為我在阻止線程完成。有什么理由使join()不能在這里工作?在

總結(jié)

以上是生活随笔為你收集整理的为什么不能用python_为什么我不能用python加入这个线程?的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。