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