- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
function1() 相对于 function2() 有什么好处(除了执行两个 GET 查询时的并行性很小)?在我看来, Controller 线程在这两种情况下都是非阻塞的,但是在等待结果时必须阻塞其中一个后台线程。举个更好的例子,当我们查看 function3() 时,我们看到 databaseDao 线程被阻塞,直到操作完成(在 dao 内部使用 JPA)。
public static F.Promise<Result> function1() {
final F.Promise<WSResponse> twitterPromise = WS.url("http://www.twitter.com").get();
final F.Promise<WSResponse> typesafePromise = WS.url("http://www.typesafe.com").get();
return twitterPromise.flatMap((twitter) -> typesafePromise.map((typesafe) -> ok(twitter.getBody() + typesafe.getBody())));
}
public static F.Promise<Result> function2() {
F.Promise<String> promise = F.Promise.promise(() -> {
HttpClient client = HttpClientBuilder.create().build();
HttpGet request1 = new HttpGet("http://www.twitter.com");
HttpGet request2 = new HttpGet("http://www.typesafe.com");
HttpResponse response = client.execute(request1);
HttpResponse response2 = client.execute(request2);
// result is not important
return response.toString() + response2.toString();
});
return promise.map(Results::ok);
}
public static F.Promise<Result> function3() {
F.Promise<String> promise = F.Promise.promise(() -> databaseDao.longRunningOperation());
return promise.map(Results::ok);
}
如果函数阻塞,我们的后台线程池就会很快消失。所以非营利组织玩框架和 promise 优于 Spring 框架和 tomcat?
编辑:
public static F.Promise<Result> function4() {
F.Promise<String> promise = F.Promise.promise(() -> {
HttpClient client = HttpClientBuilder.create().build();
HttpGet request1 = new HttpGet("http://www.twitter.com");
HttpResponse response = client.execute(request1);
return response.toString();
});
F.Promise<String> promise2 = F.Promise.promise(() -> {
HttpClient client = HttpClientBuilder.create().build();
HttpGet request2 = new HttpGet("http://www.typesafe.com");
HttpResponse response2 = client.execute(request2);
return response2.toString();
});
return promise.flatMap(p1 -> promise2.map(p2 -> ok(p1 + p2)));
}
上面的函数阻塞了两个线程,所以它比 function1 差?但是执行时间可以比较。例如,如果 promise1 需要 5 秒,promise2 需要 4 秒,结果将在 5 秒内到达?
最佳答案
What profit is from function1() over function2() (except little parallelism when two GET query is executing)?
它不仅仅是并行性。 Play WS 建立在 AsyncHttpClient 之上,这是一个非阻塞 API。在 function2
中,您似乎正在使用 Apache HttpClient ,这是一个阻塞 API。并行性有帮助。正如@Salem 已经说过的那样,function1
只会与最长的请求一样长,而 function2
每次都会与两个请求一样长。
In my opinion controller thread is non blocked in both cases, ...
是的,只要 Promise
被转移到另一个 ExecutionContext
,我们就不会阻止 Play 的内部。
...but one of background thread must be blocked when waiting for result.
不是真的。由于 function1
仅调用异步的 WS API,因此它不会阻塞等待响应的任何 线程。 function2
可能不会阻塞负责 Controller 函数的线程,但它必须在某处阻塞。这并不是说将它包装在 Promise
中是个坏主意——如果它必须阻塞,不妨在其他地方进行。
...look at function3() we see that databaseDao thread is blocked until operation is finished (inside dao JPA is used).
事实上,大多数数据库驱动程序都会阻塞,除了尝试不太流行的异步驱动程序之外,没有任何办法解决这个问题。 function2
和 function3
在行为上比 function1
和 function2
更相似。 function
确实属于它自己的一类。
If functions are blocking our background thread pool is gone fast.
是的,但大多数时候我们必须在某处进行阻塞,如果您可以选择使用异步 API,那就太好了。例如,出于上述原因,我总是使用 function1
而不是 function2
。但是对于数据库调用,我忍受了阻塞 API,因为在一个对数据库进行大量读取的应用程序中,如果我的数据库已经因查询而重载,那么节省一些应用程序线程对我来说并没有真正的帮助。
above function [function4] is blocking two threads, so it is worse than function1? But executing time can be comparable. For example if promise1 take 5second, and promise2 take 4 second, result will come in 5 second?
function4
更糟糕,因为它比 function1
阻塞了很多。这是否会立即影响应用程序的性能取决于您是否正在增加线程数。但我看不出有任何理由选择 function4
而不是 function1
。 function4
可以在与 function1
相当的时间内完成,提供它具有执行此操作所需的线程。如果池中只有一个线程可用,那么第二个 promise 可能必须等待第一个 promise 完成才能执行。在 function1
中,这不会发生。
关于java - 玩框架,promises,非阻塞线程编程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28832034/
对于一个简单的聊天程序,我使用了一个通过 boost::python 包装的 c 库。 使用 PyQT 编写了一个简单的 GUI。接收消息是通过阻塞调用完成的lib说。对于独立刷新的 GUI,通信部分
当我创建以下内容时,我试图创建一个可以被异常终止的线程类(因为我试图让线程等待一个事件): import sys class testThread(threading.Thread): def
我正在用 Haskell 编写服务器,我想在客户端断开连接后显式关闭它们。当我调用 hClose ,线程将阻塞,直到客户端关闭其一侧的句柄。有没有办法让它在不阻塞的情况下关闭? 提前致谢! 最佳答案
这个问题已经有答案了: 已关闭12 年前。 Possible Duplicate: garbage collection Operation 我有几个相关问题。 1.JAVA垃圾收集器运行时,是否占用
我有一个 Angular 函数,它在初始 URL 中查找“列表”参数,如果找到,就会出去获取信息。否则我想获得地理位置。如果存在 URL 参数,我不想获取地理位置。我使用的术语是否正确? constr
我读了很多关于锁定数据库、表和行的文章,但我想要较低的锁定,比如只锁定“操作”,我不知道如何调用它,假设我在 php 中有函数: function update_table() { //que
在我的多线程 mfc 应用程序中,m_view->SetScrollPos 处于阻塞状态并且所有应用程序都被卡住。 View 是在另一个线程中创建的,这是这种行为的原因吗? //SetScrollPo
FreeSwitch 软件在几天内运行良好(~3 - 5 天),然后由于 FreeSwitch 被阻止,新的来电请求被接受!!正在进行的调用继续他们的 session ,他们的调用似乎没有受到影响,但
我有一组按钮,当鼠标悬停在这些按钮上时,它们会改变颜色。这些的 CSS 以这种方式运行: #navsite ul li button { height: 60px; width: 60
由于某些原因,当我调用 WSARecvFrom 时,该函数在接收到某些内容之前不会返回。 _socket = WSASocket(AF_INET, SOCK_DGRAM, IPPROTO_UDP, N
我了解一些关于 Oracle 阻塞的知识——更新如何阻塞其他更新直到事务完成,写入者如何不阻塞读取者等。 我理解悲观和乐观锁定的概念,以及有关丢失更新等典型银行教科书示例。 我也理解 JDBC 事务隔
在两个代码点之间,我是否可以判断进程是否已被内核抢占,或者更确切地说,当时是否有任何其他代码在同一处理器上运行? //Point A some_type capture = some_capture(
这是我在 Oracle 的面试问题。 有一个堆栈,即使堆栈已满,push 操作也应该等到它完成,即使堆栈为空,pop 操作也应该等到它完成。 我们怎样才能做到这一点? 我的回答 让一个线程做push
我想知道是否有人可以告诉我如何有效地使用循环平铺/循环阻塞进行大型密集矩阵乘法。我正在用 1000x1000 矩阵做C = AB。我按照 Wikipedia 上的循环平铺示例进行操作,但使用平铺得到的
我正在阅读有关绿色线程的内容,并且能够理解这些线程是由 VM 或在运行时创建的,而不是由操作系统创建的,但我无法理解以下语句 When a green thread executes a blocki
我正在创建的 JavaScript API 具有以下结构: var engine = new Engine({ engineName: "TestEngine", engineHost
ChildWindow 是一个模态窗口,但它不会阻塞。有没有办法让它阻塞?我基本上想要一个 ShowDialog() 方法,该方法将调用 ChildWindow.Show() 但在用户关闭 Child
我需要一些关于如何调试 10.6 版本下的 Cocoa 并发问题的指导。我正在将“for”循环转换为使用 NSOperations,但大多数时候,代码只是在循环的某个时刻卡住。我可以在控制台中看到 N
我正在使用 ReportViewer 控件和自定义打印作业工作流程,这给我带来了一些问题。我的代码看起来有点像这样: ids.ForEach(delegate(Guid? guid)
我有以下成功复制文件的代码。但是,它有两个问题: progressBar.setValue() 之后的 System.out.println() 不会打印 0 到 100 之间的间隔(仅打印“0”直到
我是一名优秀的程序员,十分优秀!