- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在使用异步Servlet处理请求,
根据Docs :( complete(),dispatch())
╔══════════════════╦═══════════════════════════════════════════════════════════╗
║ void complete() ║ Completes the asynchronous operation and closes the ║
║ ║ response associated with this asynchronous context. ║
║ ║ You call this method after writing to the response object ║
║ ║ inside the asynchronous context. ║
╠══════════════════╬═══════════════════════════════════════════════════════════╣
║ void dispatch() ║ Dispatches the request and response objects ║
║ ║ of this AsyncContext to the servlet container. ║
╚══════════════════╩═══════════════════════════════════════════════════════════╝
async.dispatch()
和async.complete()
之间到底有什么区别? asyncContext.dispatch()
,然后再调用asyncContext.complete()
,则线程的行为是什么? asyncContext.complete()
之后调用任何方法,那么该方法调用将如何处理,如以下代码所示(在同一run()
中)? [当我对此进行测试时,它工作正常并显示相同的线程ID] run()
中调用异步方法,是否需要在callback()内完成asyncContext.complete()
? (onSuccess()或onFailure())final FutureCallback<Void> calculateTime= new CustomFuture<>(calculate);
// start Async context.
final AsyncContext asyncContext = request.startAsync();
asyncContext.start(new Runnable() {
@Override
public void run() {
MyObject object= null;
try {
object= myFactory.create();
//dispatch async context
asyncContext.dispatch("Object Successfully Created");
} catch (final IOException e1) {
logger.error("logging error");
}
asyncContext.complete(); //complete async context
// call asynchronous method
final ListenableFuture<Void> future = myService.doSomething();
Futures.addCallback(future, calculateTime);
// calling asyncContext.complete() here will work?
}
});
最佳答案
从马口中(Oracle Javadoc)
完全的()
完成在用于初始化此AsyncContext的请求上启动的异步操作,并关闭用于初始化此AsyncContext的响应。
向其创建此AsyncContext的ServletRequest注册的所有AsyncListener类型的监听器都将在其onComplete方法中被调用。
dispatch(字符串路径)
将此AsyncContext的请求和响应对象分派(dispatch)到给定路径。
...
对请求和响应的控制权委托(delegate)给分发目标,并且在完成分发目标后将关闭响应,除非调用了ServletRequest#startAsync()或ServletRequest#startAsync(ServletRequest,ServletResponse)。
问/答
dispatch
和complete
有什么区别?complete
告诉容器触发onComplete
监听器并停止异步模式,dispatch
基本上告诉容器调用complete
然后将请求(内部)转发到指定的路径。路径可以是JSP,同步Servlet或什至另一个异步Servlet,它们将触发新一轮的异步处理。dispatch
中调用run
时,响应已到达客户端,这是否意味着我们可以像这样异步推送响应?dispatch
关闭异步模式,并将请求转发到另一个servlet或JSP。要将数据推送到客户端,您必须写入与Response
关联的AsyncContext
对象。dispatch
,然后再调用complete
,则线程的行为是什么?onComplete
处理程序将被触发两次,也许对complete
的调用将无济于事,在调用处理程序和操作AsyncContext
实现的内部结构等过程中,线程与容器之间将出现竞争状态。complete
之后调用任何方法,该方法调用将如何处理dispatch
之后调用IllegalStateException
,则会抛出complete
,其他任何东西都是未定义的,因此是特定于实现的。run
中调用异步方法,是否应该在callback()中调用complete
?complete
来完成异步处理。 run
方法用于安排由容器管理的线程池执行的任务,在异步请求的生存期内可以多次调用它。AsyncStateMachine
javadoc中的状态图(Tomcat实现)。 关于java - 在处理请求时使用异步Servlet以及dispatch()和complete()方法的行为,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22867311/
我的密码 https://gist.github.com/ButuzGOL/707d1605f63eef55e4af 因此,当我收到登录成功回调时,我想进行重定向, 重定向也可以通过调度程序进行。 我
我已经写了访问者模式如下,但我不明白什么是单次和双次分派(dispatch)。AFAIK,单分派(dispatch)是根据调用者类型调用方法,而双分派(dispatch)是根据调用者类型和参数类型调用
我有一个非 ui 线程,我需要在该线程上发送消息。 执行此操作的正常方法是在我的线程的线程过程中调用 Dispatcher.Run()。 我想修改它以使其在处理未处理的异常方面更加健壮。 我的第一个剪
我有一个具有这样功能的代码 const mapDispatchToProps = (dispatch: Dispatch) => ({ onAddProduct: ( key: str
我在使用 Window.Show 显示 WPF 窗口时遇到问题: System.InvalidOperationException was unhandled Message: An unhandle
我对何时使用 Dispatcher.Invoke 从不同线程更新 UI 上的某些内容存有疑问。 这是我的代码... public Window4() { InitializeC
我遇到了一个我无法解决的问题。我正在构建一个电子商务 react 应用程序并使用 useReducer 和 useContext 进行状态管理。客户打开产品,挑选商品数量,然后单击“添加到购物车”按钮
尽管我已经深入了解了 NEventStore 上的事务完整性,但我无法理解在连接了许多 NEventStore 实例时 NEventStore 将如何真正扩展。 总结一下我的理解,一个事件被添加到提交
我学习了 React Javascript 和 Redux,现在我遇到了这个问题。 这是一个 codesandbox 像这样尝试: 搜索书名“dep” 观察日志显示“Search url is:”,当
Dispatcher.CurrentDispatcher(在System.Windows.Threading中)和Application.Current.Dispatcher(在 >系统.Window
我得到了一些代码来处理调度程序在其构造函数中传递给 View 模型的位置。我现在想知道当我想要在 UI 线程上执行某些操作时,我是否应该使用 ObserveOn(dispatcher) 或 dispa
当我们的一个应用程序服务器内存不足时,我正在分析 Java 堆转储。我正在使用 Eclipse 内存分析器。它报告了以下内容。 One instance of "akka.dispatch.Dispa
哪一个: public static let barrier: DispatchWorkItemFlags public static let detached: DispatchWorkItem
我想使用不同于调度类型的类型提示 Action 创建者。 我已经尝试使用这两种类型对 ThunkResult 进行类型提示,但这并不理想。 // types.ts interface AppListA
我正在尝试准确地理解什么是单次分派(dispatch)和多次分派(dispatch)。 我刚刚读到这个: http://en.wikipedia.org/wiki/Multiple_dispatch
I have following api returning Flux of String我有以下返回字符串通量的接口 @GetMapping(value = "/api/getS
这是我自学前端开发一年后在Stackoverflow上的第一个问题。我已经找到了我的疑惑的答案,但由于这些问题是第三次返回,我认为是时候向 Web 提问了。 我正在尝试构建什么 我正在尝试构建一个图书
我正在使用 Kotlin 学习 Android,并且我了解到在不阻塞主线程的情况下启动协程的推荐方法是执行以下操作 MainScope().launch { withContext(Dispatc
错误本身: (alias) deleteCategory(id: number): (dispatch: Dispatch) => void import deleteCategory Argumen
我必须对抽屉进行裁剪,然后创建一个包含所有需要项的DrawerComponent,并创建一个带有NavigationActions的函数来调度我的路线,但是它不起作用。当我单击任何项目时,我都会遇
我是一名优秀的程序员,十分优秀!