最近看swoole,有个教程是动态加线程,用timer的tick分发任务。
首先tick和其对应的线程内存不共享。其次动态弄线程,对线程队列进行添加。
两者相结合,即线程添加只能在分发任务的tick中执行。
但是swoole中在tick中加线程会报凑“Uncaught Swoole\Error: must be forked outside the coroutine”。
加swoole_async_set(['enable_coroutine' => false,]);能解决问题,但是被创建线程对应的监听不会起作用。
所以要是swoole中在主线程创建的子进程队列中并分发任务,且可动态创建线程。在swoole4中使用tick处理不可取。早期版本可以。
process/pool其构造就要求传入线程数,也没有加线程的方法。
process/Manager可以添加线程,回调的Pool对象也是指一个线程。但是它是堵塞执行,启动之后其余代码不执行。这样就无法判断是否添加线程。
对于这种需求,直接线程数写死就好。