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();

                    }

                });

  • 相关阅读:
    堆排序
    append、appendTo、prepend、prependTo、before、insertBefore、after、insertAfter、replaceAll方法被调用后,原本在页面上显示的元素会消失
    jQuery中的 $.ajax的一些方法
    attr VS prop 区别
    Canvas---clearRect()清除圆形区域
    HTML5 FormData方法介绍
    MongoDB学习笔记——数据库的创建与初始
    es6学习---.babelrc文件
    【转载】基于webpack构建react项目
    node常用模块---path
  • 原文地址:https://www.cnblogs.com/qf-dd/p/10097989.html
Copyright © 2011-2022 走看看