[英]Java Client Server, Multi-threading
我目前正在编写客户端服务器JAVA应用程序的代码,有点卡住了。 我在网上搜索了一些有用的代码。 我找到了这个示例(我想在等待连接时使用它),但是我不太了解这段代码应该做什么,难道有人可以帮忙吗? :)
Executor threadpool = Executors.newScheduledThreadPool(maxClients);
Executor界面和Executors Factory可帮助您使用ThreadPools。
在您的情况下:您想同时处理传入的客户端连接。 因此,每个都需要一个线程。 因此,将任务提交给执行者是一种不被线程创建等困扰的便捷方法。
所以线
Executor threadpool = Executors.newScheduledThreadPool(maxClients);
将threadpool
声明为Executor(可以稍后将Tasks提交给Executor),但是您不在乎哪个实现。 然后,“ =”的右侧将使用Factory检索Executor的一种实现的实例。 在这种情况下,它是一个ScheduledThreadPool
其中至少有maxClients
线程在等待新任务。
在代码中,它可能会像
threadpool.execute( new ClientHandler(socket) );
其中ClientHandler是一些实现Runnable的帮助程序类,该类与Client一起处理IO。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.