NetBeans / Java /新提示:Thread.sleep在循环中调用
在NetBeans中,有一个新提示:
循环睡眠的时间/时间是什么时候?
如果有问题,我该怎么办?
这是一些代码。在这种情况下,请告诉我是否应该在循环中使用其他方法代替Thread.Sleep。简而言之,它由侦听客户端TCP连接的服务器使用。如果达到与客户端的最大会话数,则在此处使用睡眠。在这种情况下,我希望应用程序等待一个空闲会话可用。
public class SessionManager { private static final int DEFAULT_PORT = 7500;
private static final int SLEEP_TIME = 200;
private final DatabaseManager database = new DatabaseManager();
private final ServerSocket serverSocket = new ServerSocket(DEFAULT_PORT);
public SessionManager() throws IOException, SQLException
{
}
public void listen()
{
while (true)
if (Session.getSessionCount() < Session.getMaxSessionCount())
try
{
new Thread(new Session(database, serverSocket.accept())).start();
}
catch (IOException ex) { ex.printStackTrace(); }
else
try
{
Thread.sleep(SLEEP_TIME);
}
catch (InterruptedException ex) { ex.printStackTrace(); }
}
public static void main(String[] args) throws IOException, SQLException
{
new SessionManager().listen();
}
}
回答:
循环调用睡眠通常会导致性能下降。例如:
while (true) { if (stream.available() > 0) {
// read input
}
sleep(MILLISECONDS);
}
如果MILLISECONDS太大,则此代码将花费很长时间才能意识到输入可用。
如果MILLISECONDS太小,则此代码将浪费大量系统资源,以检查尚未到达的输入。
sleep
循环中的其他用途通常也很可疑。通常有更好的方法。
如果有问题,我该怎么办?
发布代码,也许我们可以给您一个明智的答案。
IMO,解决此问题的更好方法是使用ThreadPoolExecutor
。
像这样:
public void listen() { BlockingQueue queue = new SynchronousQueue();
ThreadPoolExecutor executor = new ThreadPoolExecutor(
1, Session.getMaxSessionCount(), 100, TimeUnit.SECONDS, queue);
while (true) {
try {
queue.submit(new Session(database, serverSocket.accept()));
} catch (IOException ex) {
ex.printStackTrace();
}
}
}
这会将执行程序配置为匹配您的代码当前的工作方式。您可以通过多种其他方式来做到这一点。请参阅上面的javadoc链接。
以上是 NetBeans / Java /新提示:Thread.sleep在循环中调用 的全部内容, 来源链接: utcz.com/qa/401521.html