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

回到顶部