首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从执行时间为true的函数返回对象

从执行时间为true的函数返回对象
EN

Stack Overflow用户
提问于 2016-05-13 18:36:51
回答 1查看 23关注 0票数 0

以一种非常天真的方式,我试图保存到一个gzip文件。我在一个单独的线程中将该文件的队列块添加到队列中,因为gzip压缩的开销相当大。我在internet中找到的使用多线程的最简单的解决方案是定义一个新函数,它以这种方式从队列中读取:

代码语言:javascript
复制
def savegz(filegz, workQueue):
  while True:
    user_list = workQueue.get()
    print 'start'
    for chunck in user_list: 
      filegz.writelines(chunck)
    print 'end'
    workQueue.task_done()

...
workQueue = Queue(0)
thread1 = Thread(target=savegz, args=(filegz, workQueue))
thread1.setDaemon(True)
thread1.start()
...
for user_list in something(a):
  workQueue.put(user_list)
...
workQueue.join()
filegz.close()

但这样它就永远不会印出“终点”。我知道这不是保存文件的好方法,但我认为问题是我从来不返回filegz。但我不想退货,因为这样我就退出了。我看到了产量函数,但我不认为它会起作用。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-05-13 18:46:59

我认为thread1不应该是守护进程,或者您应该在thread1上使用join

您需要一种方法来通知thread1,没有更多的项目。您可以在队列上放置一个特殊值,以指示如下:

代码语言:javascript
复制
def savegz(filegz, workQueue):
  while True:
    user_list = workQueue.get()
    if user_list == None:
      break
    print 'start'
    for chunck in user_list:
      filegz.writelines(chunck)
    print 'end'
    workQueue.task_done()

...
workQueue = Queue(0)
thread1 = Thread(target=savegz, args=(filegz, workQueue))
thread1.setDaemon(False)
thread1.start()
...
for user_list in something(a):
  workQueue.put(user_list)
...
workQueue.put(None)
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37217120

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档