8

例如,在使用 http 包或进行一般 IO 操作时颤动

import 'package:http/http.dart' as http;

http.Response response = await http.get(url);
if (response.statusCode == 200) {
  var json = jsonDecode(response.body); 
}

我已通读引擎架构,表明引擎中有 4 个线程

  • 平台任务运行器
  • UI 任务运行器
  • GPU 任务运行器
  • IO 任务运行器

主应用程序 dart 代码在 UI 任务运行线程上运行。IO 任务运行器似乎仅用于 dart 引擎读取图像处理耗时的图像 IO,而不是应用程序 IO 发生的位置?

我知道 IO 库具有基于 Future 的无阻塞接口,因此我提供给 IO 库的回调将在 UI 线程上运行,但是实际的 IO 操作本身呢? Dart VM 正在使用 OS 线程来执行这些操作操作?

例如,如果我尝试上传/下载 800MB 的视频文件,是否有 Dart VM 使用的后台 IO 线程来执行实际的 IO?

是否应该将单独的隔离用于大型 IO 操作,例如上传/下载大文件?

4

1 回答 1

12

Dart 使用线程池处理 IO 请求。为了找出答案,我必须克隆 Dart SDK 并查看源代码,因为我无法从文档中找到答案。

调用 IO 方法时,会调用 File 实现_File类方法。它创建一个到本机代码的端口 ( IOService_NewServicePort) 并将 IO 请求 id 和 args 发送到本机代码。runtime\vm\native_api_impl.cc#Dart_NewNativePort本机代码使用线程池 ( )处理 IO 请求,将任务提交到线程池中。然后原生代码一路返回 Dart 代码并_File返回一个未来对象。IO操作完成后,通过之前创建的端口将结果从native传回Dart。这会触发在端口上注册的处理程序,并且未来已解决。

于 2020-03-18T07:48:53.353 回答