Python 板


LINE

程式码在 https://ideone.com/3ZTGat opencc是下面这个版本 https://pypi.org/project/opencc-python-reimplemented/ 环境是python3.8, windows8. #1 result = [] #2 for i in range(total): #3 res = pool.apply_async(self.func1, args=(i,)) #4 result.append(res) #5 pool.close() #6 #pool.join() #7 self.aa = OpenCC('s2twp') 1. 如果self.aa有设值,程式跑完需要16秒 2. self.aa拿掉的话0.13秒就跑完 3. 如执行pool.join(),结果是0.18秒 4. 把#7把放pool.join前面,并执行pool.join(),结果16秒 5. 把#7加到__init__,并执行pool.join(),结果16秒 6. 把self.aa = OpenCC(..)改成 aa=OpenCC(..), 0.1x秒 感觉只要apply_async的任务跑完前,把OpenCC指给self,就会卡卡的, 问题感觉是出在opencc, 请问有可能是什麽原因? opencc只有一只py档,就下面这只 https://github.com/yichen0831/opencc-python/blob/master/opencc/opencc.py --



※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 220.136.87.190 (台湾)
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/Python/M.1587924129.A.4A3.html
1F:→ djshen: 不懂和multiprocessing有什麽关系 04/27 02:39
2F:→ MARGHT: 的确没关系 04/27 03:24
https://ideone.com/r139RS 拿掉multiprocess, 跑起来就0.1x秒,不受self.aa影响
3F:推 TuCH: 开multiprocess 成本很高 开了是要丢大量运算 平行化的效果 04/27 18:06
4F:→ TuCH: 才显现得出来 04/27 18:06
5F:推 WusoAiwen: 没有大量运算用multiprocess反而会变慢 04/27 19:48
问题是慢得很奇怪,应该跟没有大量运算用multiprocess反而会变慢无关 吧(看第6点)? ※ 编辑: tsaiminghan (220.136.107.184 台湾), 04/27/2020 19:58:55
6F:推 extraymond: 在linux下面跑,最花时间的是24行,拿掉就0.1x秒 04/27 21:45
7F:推 extraymond: 不过满不固定的,你原始的code有时候也会0.1X秒 04/27 21:53
8F:→ extraymond: 如果你把self.func1移出a,最慢的情况会变成0.3X 04/27 21:55
9F:→ extraymond: 印象位置multiprocess你传object进去,他会复制整份 04/27 21:57
10F:→ extraymond: a,包含a.test 时间差异应该从这边找应该会有些结果 04/27 21:57
我在windows上也试了,如你所说,如果把fun1移出class,会快很多。 我再试试看,谢谢。
11F:→ djshen: map的时候会pickle method, 刚好你传的是bound method 04/27 22:55
12F:→ djshen: 会把整个object一起pickle 然後传到child process 04/27 22:55
13F:→ djshen: 又刚好pickle是在get的时候才call 04/27 22:55
14F:→ djshen: 你可以试试看print(len(pickle.dumps(self.func1))) 04/27 22:56
15F:→ djshen: 一开始想成copy on write 04/27 22:58
谢谢,我去找找pickle的资料看看 总结上面两位的说法,时间是花在pickle obj,所以如果self.aa = OpenCC(..)时,连 OpenCC也会被pickle,所以如果有加join(),等multiprocess跑完,才有OpenCC,所以 OpenCC没有被pickle。 因此multiprocess传入的参数要尽量简单,才不会有这问题罗? ※ 编辑: tsaiminghan (220.136.107.184 台湾), 04/27/2020 23:42:02
16F:→ AndCycle: 你要考虑跑 process 起来的代价跟考虑他会活多久 04/29 00:08
17F:→ zerof: 楼楼上正解 04/30 23:54
18F:推 jn8029: https://tinyurl.com/y9bazr5g 05/04 22:00







like.gif 您可能会有兴趣的文章
icon.png[问题/行为] 猫晚上进房间会不会有憋尿问题
icon.pngRe: [闲聊] 选了错误的女孩成为魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一张
icon.png[心得] EMS高领长版毛衣.墨小楼MC1002
icon.png[分享] 丹龙隔热纸GE55+33+22
icon.png[问题] 清洗洗衣机
icon.png[寻物] 窗台下的空间
icon.png[闲聊] 双极の女神1 木魔爵
icon.png[售车] 新竹 1997 march 1297cc 白色 四门
icon.png[讨论] 能从照片感受到摄影者心情吗
icon.png[狂贺] 贺贺贺贺 贺!岛村卯月!总选举NO.1
icon.png[难过] 羡慕白皮肤的女生
icon.png阅读文章
icon.png[黑特]
icon.png[问题] SBK S1安装於安全帽位置
icon.png[分享] 旧woo100绝版开箱!!
icon.pngRe: [无言] 关於小包卫生纸
icon.png[开箱] E5-2683V3 RX480Strix 快睿C1 简单测试
icon.png[心得] 苍の海贼龙 地狱 执行者16PT
icon.png[售车] 1999年Virage iO 1.8EXi
icon.png[心得] 挑战33 LV10 狮子座pt solo
icon.png[闲聊] 手把手教你不被桶之新手主购教学
icon.png[分享] Civic Type R 量产版官方照无预警流出
icon.png[售车] Golf 4 2.0 银色 自排
icon.png[出售] Graco提篮汽座(有底座)2000元诚可议
icon.png[问题] 请问补牙材质掉了还能再补吗?(台中半年内
icon.png[问题] 44th 单曲 生写竟然都给重复的啊啊!
icon.png[心得] 华南红卡/icash 核卡
icon.png[问题] 拔牙矫正这样正常吗
icon.png[赠送] 老莫高业 初业 102年版
icon.png[情报] 三大行动支付 本季掀战火
icon.png[宝宝] 博客来Amos水蜡笔5/1特价五折
icon.pngRe: [心得] 新鲜人一些面试分享
icon.png[心得] 苍の海贼龙 地狱 麒麟25PT
icon.pngRe: [闲聊] (君の名は。雷慎入) 君名二创漫画翻译
icon.pngRe: [闲聊] OGN中场影片:失踪人口局 (英文字幕)
icon.png[问题] 台湾大哥大4G讯号差
icon.png[出售] [全国]全新千寻侘草LED灯, 水草

请输入看板名称,例如:BuyTogether站内搜寻

TOP