queue 模块对象的 task_done 方法有什么用? - V2EX
首页
注册
登录
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请
登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI
- Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
V2EX
Python
queue 模块对象的 task_done 方法有什么用?
defias
2015 年 11 月 1 日
5059 次点击
这是一个创建于 3829 天前的主题,其中的信息可能已经有所发展或是发生改变。
python 的 queue 队列中的任务取出一个执行完后,需要调用 task_done 方法来通知 queue ,不知道这个有什么作用,因为本来 get 方法在从 queue 中取任务时,就会从 queue 中删掉已取出的任务。如果不调用 task_done 会怎么样?比如当 get 取出一个任务后执行完又 put 放回 queue 中的情况。
Queue
task_done
取出
调用
4 条回复
2015-11-01 13:07:50 +08:00
1
exploitcat
2015 年 11 月 1 日
不 task_done 线程退不出来,队列是阻塞的
2
Damnever
2015 年 11 月 1 日
放入队列的个数要和 task_done 调用次数相等,也就是说你每取出来一个,必须 task_done ,要不然计数不相等, join 的时候就不知道什么时候退出
3
lcqtdwj
2015 年 11 月 1 日
这是一种同步机制
4
defias
OP
2015 年 11 月 1 日
谢谢各位的回复,大概的明白了一些。
@
Damnever
你这里的 join 应该指的是队列的 join : Queue.join() 吧,如果代码中没用用到 Queue.join() 而是用线程的 join ,即主线程中用 sonthread.join(60)来等待子线程运行完成或超时,而不关心 queue 中的任务是否完成(因为可能根本无法完成),那么是否从 queue 中取出来一个后,用不用 task_done 都没关系了
关于
帮助文档
自助推广系统
博客
API
FAQ
Solana
2726 人在线
最高记录 6679
Select Language
创意工作者们的社区
World is powered by solitude
VERSION: 3.9.8.5 34ms
UTC 06:29
PVG 14:29
LAX 23:29
JFK 02:29
Do have faith in what you're doing.
ubao
msn
snddm
index
pchome
yahoo
rakuten
mypaper
meadowduck
bidyahoo
youbao
zxmzxm
asda
bnvcg
cvbfg
dfscv
mmhjk
xxddc
yybgb
zznbn
ccubao
uaitu
acv
GXCV
ET
GDG
YH
FG
BCVB
FJFH
CBRE
CBC
GDG
ET54
WRWR
RWER
WREW
WRWER
RWER
SDG
EW
SF
DSFSF
fbbs
ubao
fhd
dfg
ewr
dg
df
ewwr
ewwr
et
ruyut
utut
dfg
fgd
gdfgt
etg
dfgt
dfgd
ert4
gd
fgg
wr
235
wer3
we
vsdf
sdf
gdf
ert
xcv
sdf
rwer
hfd
dfg
cvb
rwf
afb
dfh
jgh
bmn
lgh
rty
gfds
cxv
xcv
xcs
vdas
fdf
fgd
cv
sdf
tert
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
sdf
shasha9178
shasha9178
shasha9178
shasha9178
shasha9178
liflif2
liflif2
liflif2
liflif2
liflif2
liblib3
liblib3
liblib3
liblib3
liblib3
zhazha444
zhazha444
zhazha444
zhazha444
zhazha444
dende5
dende
denden
denden2
denden21
fenfen9
fenf619
fen619
fenfe9
fe619
sdf
sdf
sdf
sdf
sdf
zhazh90
zhazh0
zhaa50
zha90
zh590
zho
zhoz
zhozh
zhozho
zhozho2
lislis
lls95
lili95
lils5
liss9
sdf0ty987
sdft876
sdft9876
sdf09876
sd0t9876
sdf0ty98
sdf0976
sdf0ty986
sdf0ty96
sdf0t76
sdf0876
df0ty98
sf0t876
sd0ty76
sdy76
sdf76
sdf0t76
sdf0ty9
sdf0ty98
sdf0ty987
sdf0ty98
sdf6676
sdf876
sd876
sd876
sdf6
sdf6
sdf9876
sdf0t
sdf06
sdf0ty9776
sdf0ty9776
sdf0ty76
sdf8876
sdf0t
sd6
sdf06
s688876
sd688
sdf86