zoukankan      html  css  js  c++  java
  • AsyncContext异步和多线程区别

    AsyncContext不是异步输出时使用的,而是同步输出,但是解放服务器端的线程使用,使用AsyncContext的时候,对于浏览器来说,他们是同步在等待输出的,但是对于服务器端来说,处理此请求的线程并没有卡在那里等待,则是把当前的处理转为线程池处理了,关键就在于线程池,服务器端会起一个线程池去服务那些需要异步处理的请求,而如果自己每次请求去起一个线程处理的话,这就有可能会耗大量的线程。

    目前对AsyncContext 的使用并不是最佳实践,实际上应该这样使用:

    final AsyncContext asyncContext = request.getAsyncContext();

                asyncContext.addListener(new AsyncListener() {

                    @Override

                    public void onComplete(AsyncEvent event) throws IOException {

                        //在这里处理正常结束的逻辑

                    }

                    @Override

                    public void onTimeout(AsyncEvent event) throws IOException {

                        //在这里处理超时的逻辑

                    }

                    @Override

                    public void onError(AsyncEvent event) throws IOException {

                        //在这里处理出错的逻辑

                    }

                    @Override

                    public void onStartAsync(AsyncEvent event) throws IOException {

                        //在这里处理开始异步线程的逻辑

                    }

                });

                //设置超时的时间,到了时间以后,会回调onTimeout的方法

                asyncContext.setTimeout(10000L);

                //在这里启动,传入一个Runnable对象,服务器会把此Runnable对象放在线程池里面执行

                asyncContext.start(new Runnable() {

                    @Override

                    public void run() {

                        //在这里做耗时的操作,如果做完,则调用complete方法通知回调,异步处理结束了

                        asyncContext.complete();

                    }

                });

  • 相关阅读:
    springboot下使用多线程
    springboot 下测试 service中的方法
    maven 将本地jar包 安装到本地仓库
    idea下http响应乱码
    使用vue-element-admin框架时如何添加多级目录
    如何在uniapp中使用mqtt
    在uniapp设计的APP中引入axios,支持cookie(真机亲测可行)
    vue中get方法如何传递数组参数
    Vue跨域访问,axios&cors
    Vue页面间传值,客户端数据存储,以及父子组件间props传值
  • 原文地址:https://www.cnblogs.com/qf-dd/p/10097989.html
Copyright © 2011-2022 走看看