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

                    }

                });

  • 相关阅读:
    微信跳一跳,Python辅助自动跳程序
    关于 adb devices找不到的解决方法
    vue--axios使用post方法与后台进行异步传值是报错POST http://localhost:8080/api/AddEmployeeApi 405 (METHOD NOT ALLOWED)
    vue 中引入外部css路径中使用@报错,提示找不到文件
    centos7服务器配置接口供外网调用
    排球计分程序改进
    排球计分程序(九)——总结
    排球计分程序(八)——验证编辑方法(Edit method)和编辑视图(Edit view)
    排球计分(七)—— 使用EF框架,创建Controller,生成数据库
    排球计分程序(六)——接口的设计与实现
  • 原文地址:https://www.cnblogs.com/qf-dd/p/10097989.html
Copyright © 2011-2022 走看看