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

                    }

                });

  • 相关阅读:
    lodash-es 最小化引入
    shortid id生成器
    结构体声明的方式 及类namespace的前置声明
    结构体中使用 箭头 与 点 的区别
    进入Docker容器的几种方式
    协议分析处理工具ProtoBuf
    PubSub ——“发布/订阅”模式
    在Windows/linux下进行gdb调试
    C++中的域作用符::的作用
    C++ 中常用关键字及其用法
  • 原文地址:https://www.cnblogs.com/qf-dd/p/10097989.html
Copyright © 2011-2022 走看看