java – 为多线程REST API客户端设计

我正在开发一个程序,它接收一个主题的搜索请求,对纽约时报API进行API调用以获取与该主题相关的文章,然后到Twitter API获取提及文章的推文,最后处理结果并返回回来了.

我必须使这个多线程.我想过使用具有固定大小的线程池的ExecutorService.因此,每个传入的搜索请求都将由一个单独的线程处理.我还使用Callable接口来提交任务.实现Callable的类执行API处理(制作和接收API请求/响应).最后,结果然后由Future获取并显示为输出.每次传入请求都会发生这种情况

这有意义吗?或者有更好的方法吗?

编辑:我在我的本地机器上运行它接受来自命令行界面的数据.

解决方法:

如果这是一个Web应用程序,默认情况下它是多线程的.如果不是 – 你仍然可以将它部署在servlet容器上,那将是有益的.线程池由底层容器(例如tomcat)提供.每个请求都由一个单独的线程提供服务.

唯一需要关心的事情:

>不要使用synchronized
>清理您使用的任何ThreadLocal变量

上一篇:1、创建线程的方式及实现


下一篇:JAVA多线程实现的四种方式