python 多线程时报错:TypeError: cannot pickle ‘_thread.lock‘ object

在学习分布式爬虫时遇到Process.start()引发的错误,尝试将Process.start()改为Process.run()虽消除报错,但丧失了多线程特性。问题根源在于queue.Queue不支持多线程,解决方案是改用multiprocessing.Queue。修改后,成功实现多线程并解决报错。
摘要由CSDN通过智能技术生成

在学习分布式爬虫时,遇到已下报错:

在网上搜了下,普遍都是这一种解决办法,降Process.start()改成Process.run(),试了一下,确实不再报错,但是同时也不是多线程。参考文章:https://blog.csdn.net/weixin_42081389/article/details/93172508

继续搜索,终于找到不一样,

https://blog.csdn.net/attackkk/article/details/102028534?utm_medium=distribute.pc_relevant.none-task-blog-2%7Edefault%7EBlogCommendFromBaidu%7Edefault-6.base&depth_1-utm_source=distribute.pc_relevant.none-task-blog-2%7Edefault%7EBlogCommendFromBaidu%7Edefault-6.base

原来是queue.Queue 这个数据类型不支持多线程,将此队列改成multiprocessing中的Queue队列即可解决问题

 

 

评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值