关于 Python 多线程的一点疑问

2016-10-19 15:03:44 +08:00
 scriptkid

本人学 Python 主要是通过《 Python 核心编程第二版》自学的,关于多线程方面该书是推荐使用 threading 而不用 thread ,一般都是使用重写 run 方法或者类似如下代码:

    threads = []
    for i in nloops:
        t = threading.Thread(target=func,args=(i,arg))
        threads.append(t)
    for t in threads:
        t.start()
    for t in threads:
        t.join()

当然,可能还会涉及到生产者消费者的问题,但是就目前已查阅到的各方面资料,好像大多数并未提及多线程问题中常见的线程数
那么,如上的 Python 多线程的线程数是多少?又该怎样自己设置线程数?(如果有这种说法)
除此之外还想问的是怎样才能更好地使用 Python 的多线程,怎么确定要不要用生产者消费者的方式?
以上,坐等老司机指点

2169 次点击
所在节点    Python
3 条回复
GeekGao
2016-10-19 15:49:30 +08:00
静态的看此段代码,会开启 nloops 个线程,至于设置线程数看你创建多少线程对象并且 start 了;
生产者与消费者,要看你的具体业务是啥,如果是本地应用,我认为一般的设计是可以拆成独立的类 /模块,各自干各自的。当然最好用线程池了(若生产者+消费者都为多线程,模式同理),减少创建线程的开销,更好的控制你的线程。
ryd994
2016-10-20 00:35:59 +08:00
一般你这种情况不直接用线程,用 thredpool map 一下最方便
264768502
2016-10-20 07:32:42 +08:00
因为 CPython 有 GIL ,所以多线程的意义不是那么大了(比如 CPU 密集就该多进程, IO 密集就异步)
具体多少线程合适要实际测试下才知道

针对 LZ 的这个简单情况,一定要用多线程的话,可以看看 multiprocess.dummy 里现成的线程池 pool

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/313875

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX