在下面的示例中(来自Embarcadero的手册),MyValue将在大约3秒后被检索。但是,主gui线程将被等待结果的MyValue := FutureObject.Value;调用阻塞。如果未来的代码需要很长的时间,比如说30秒,Windows将在我猜的程序标题中显示一个“.没有响应”。那么,当它将阻塞主gui线程时,它的目的是什么?有没有其他方法可以在不阻塞主gui线程的情况下获得结果?
FutureObject := TTask.Future<Integer>(function: Integer
begin
Sleep(3000);
Result := 16;
end);
// …
MyValue := FutureObject.Value;发布于 2017-11-26 18:08:25
通过设计,IFuture.Value属性将阻塞调用线程,直到另一个线程分配一个值。因此,如果在主线程中读取Value,它将阻塞主线程,直到一个值准备就绪为止。
如果必须在主线程中不阻塞地读取Value,则可以:
IFuture.Status属性,以检查IFuture何时准备好在实际读取值之前提供值。Value。发布于 2019-08-05 14:23:26
我知道这可能有点晚,但我通过创建一个TTask来解决这个问题,它完成了MyValue := FutureObject.Value
FutureObject := TTask.Future<Integer>(function: Integer
begin
Sleep(3000);
Result := 16;
end);
// …
TTask.Run(Procedure begin
MyValue := FutureObject.Value;
end);https://stackoverflow.com/questions/47495352
复制相似问题