本人学 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 的多线程,怎么确定要不要用生产者消费者的方式?
以上,坐等老司机指点
1
GeekGao 2016-10-19 15:49:30 +08:00
静态的看此段代码,会开启 nloops 个线程,至于设置线程数看你创建多少线程对象并且 start 了;
生产者与消费者,要看你的具体业务是啥,如果是本地应用,我认为一般的设计是可以拆成独立的类 /模块,各自干各自的。当然最好用线程池了(若生产者+消费者都为多线程,模式同理),减少创建线程的开销,更好的控制你的线程。 |
2
ryd994 2016-10-20 00:35:59 +08:00 via Android
一般你这种情况不直接用线程,用 thredpool map 一下最方便
|
3
264768502 2016-10-20 07:32:42 +08:00 via iPad
因为 CPython 有 GIL ,所以多线程的意义不是那么大了(比如 CPU 密集就该多进程, IO 密集就异步)
具体多少线程合适要实际测试下才知道 针对 LZ 的这个简单情况,一定要用多线程的话,可以看看 multiprocess.dummy 里现成的线程池 pool |