【发布时间】:2010-08-16 16:50:20
【问题描述】:
在对象构造函数中启动线程池是否安全?我知道你不应该从构造函数启动线程,关于“this”指针转义的事情(我不完全理解这一点,但会做更多的搜索来尝试弄清楚)。
代码如下所示:
private ExecutorService pool;
public handler()
{
pool = Executors.newCachedThreadPool();
}
public void queueInstructionSet(InstructionSet set)
{
pool.submit(new Runnable that handles this instruction set);
}
如果这不起作用,我可以将此类创建为 Runnable 并在新线程中启动它。但是,这似乎会给程序添加一个不必要的线程,而它实际上并不需要它。
谢谢。
编辑:
感谢大家的回复,他们肯定有助于理解这一点。
根据代码,在我看来,这个构造函数创建线程池是有道理的,但让我解释一下这段代码具体在做什么,因为我可能正在以一种奇怪的方式思考这个问题。
这个对象的全部意义在于获取“指令集”对象,并相应地对它们进行操作。指令集来自连接到服务器的客户端。一旦从客户端接收到完整的指令集,就会将该指令集发送到此对象(处理程序)进行处理。
此处理程序对象包含对指令集可以操作的每个对象的引用。它将指令集提交给线程池,线程池会找到该指令集要与哪个对象进行交互,然后处理该对象上的指令集。
我可以处理 IO 服务器中的指令集对象,但我的想法是有一个单独的类,因为它使整个代码更具可读性,因为每个类只专注于做一件特定的事情。
想法?建议?
谢谢
【问题讨论】:
标签: java threadpool