Dart 概览
Dart 是一种为在任何平台上开发快速应用而优化的客户端语言。其目标是为多平台开发提供最高效的编程语言,并搭配用于应用框架的灵活的执行运行时平台。
语言由其技术范围定义——开发过程中做出的选择塑造了语言的功能和优势。Dart 的设计技术范围特别适合客户端开发,优先考虑开发(亚秒级有状态热重载)和跨各种编译目标(Web、移动和桌面)的高质量生产体验。
Dart 也是 Flutter 的基础。Dart 提供了驱动 Flutter 应用的语言和运行时,但 Dart 也支持许多核心开发者任务,例如格式化、分析和测试代码。
Dart:语言
#Dart 语言是类型安全的;它使用静态类型检查来确保变量的值始终与其静态类型匹配。有时,这被称为健全类型。尽管类型是强制性的,但由于类型推断,类型注解是可选的。Dart 类型系统也很灵活,允许使用 dynamic
类型并结合运行时检查,这在实验期间或对于需要特别动态的代码可能很有用。
Dart 内置了健全的空安全。这意味着值不能为 null,除非您明确声明它们可以为 null。借助健全的空安全,Dart 可以通过静态代码分析来保护您免受运行时 null 异常的困扰。与许多其他空安全语言不同,当 Dart 确定变量不可为空时,该变量永远不能为 null。如果您在调试器中检查正在运行的代码,您会看到不可为空性在运行时得到保留;因此称为健全的空安全。
以下代码示例展示了几个 Dart 语言特性,包括库、异步调用、可空和不可空类型、箭头语法、生成器、Stream 和 getter。要了解有关该语言的更多信息,请查看Dart 语言之旅。
import 'dart:math' show Random;
void main() async {
print('Compute π using the Monte Carlo method.');
await for (final estimate in computePi().take(100)) {
print('π ≅ $estimate');
}
}
/// Generates a stream of increasingly accurate estimates of π.
Stream<double> computePi({int batch = 100000}) async* {
var total = 0; // Inferred to be of type int
var count = 0;
while (true) {
final points = generateRandom().take(batch);
final inside = points.where((p) => p.isInsideUnitCircle);
total += batch;
count += inside.length;
final ratio = count / total;
// Area of a circle is A = π⋅r², therefore π = A/r².
// So, when given random points with x ∈ <0,1>,
// y ∈ <0,1>, the ratio of those inside a unit circle
// should approach π / 4. Therefore, the value of π
// should be:
yield ratio * 4;
}
}
Iterable<Point> generateRandom([int? seed]) sync* {
final random = Random(seed);
while (true) {
yield Point(random.nextDouble(), random.nextDouble());
}
}
class Point {
final double x;
final double y;
const Point(this.x, this.y);
bool get isInsideUnitCircle => x * x + y * y <= 1;
}
Dart:库
#Dart 拥有丰富的核心库集,为许多日常编程任务提供必需品
- 每个 Dart 程序的内置类型、集合和其他核心功能 (
dart:core
) - 更丰富的集合类型,例如队列、链表、哈希映射和二叉树 (
dart:collection
) - 用于在不同数据表示形式(包括 JSON 和 UTF-8)之间转换的编码器和解码器 (
dart:convert
) - 数学常数和函数,以及随机数生成 (
dart:math
) - 异步编程支持,具有
Future
和Stream
等类 (dart:async
) - 有效处理固定大小数据(例如,无符号 8 字节整数)和 SIMD 数值类型的列表 (
dart:typed_data
) - 非 Web 应用程序的文件、套接字、HTTP 和其他 I/O 支持 (
dart:io
) - 用于与其他呈现 C 风格接口的代码进行互操作的外部函数接口 (
dart:ffi
) - 使用隔离的并发编程——类似于线程但不共享内存的独立工作器,仅通过消息进行通信 (
dart:isolate
) - Web 应用程序的 HTML 元素和其他资源,这些应用程序需要与浏览器和文档对象模型 (DOM) 交互 (
dart:js_interop
和package:web
)
除了核心库之外,许多 API 通过一套全面的包提供。Dart 团队发布了许多有用的补充包,例如这些
此外,第三方发布者和更广泛的社区发布了数千个包,支持以下功能
要查看一系列以 Dart 核心库为特色的工作示例,请阅读核心库文档。要查找其他 API,请查看常用包页面。
Dart:平台
#Dart 的编译器技术使您能够以不同的方式运行代码
原生平台:对于面向移动和桌面设备的应用程序,Dart 既包含带有即时 (JIT) 编译的 Dart VM,也包含用于生成机器代码的提前 (AOT) 编译器。
Web 平台:对于面向 Web 的应用程序,Dart 可以为开发或生产目的进行编译。其 Web 编译器将 Dart 翻译成 JavaScript 或 WebAssembly。
Flutter 框架是一个流行的多平台 UI 工具包,它由 Dart 平台驱动,并提供工具和 UI 库来构建在 iOS、Android、macOS、Windows、Linux 和 Web 上运行的 UI 体验。
Dart Native(机器代码 JIT 和 AOT)
#在开发过程中,快速的开发者周期对于迭代至关重要。Dart VM 提供了一个带有增量重新编译(启用热重载)、实时指标收集(驱动 DevTools)和丰富的调试支持的即时编译器 (JIT)。
当应用程序准备好部署到生产环境时——无论您是发布到应用商店还是部署到生产后端——Dart 提前 (AOT) 编译器都可以编译为原生 ARM 或 x64 机器代码。您的 AOT 编译应用程序以一致的、短的启动时间启动。
AOT 编译的代码在高效的 Dart 运行时内运行,该运行时强制执行健全的 Dart 类型系统,并使用快速对象分配和分代垃圾回收器管理内存。
更多信息
Dart Web(JavaScript 开发与生产以及 WebAssembly)
#Dart Web 允许在由 JavaScript 驱动的 Web 平台上运行 Dart 代码。借助 Dart Web,您可以将 Dart 代码编译为 JavaScript 代码,然后 JavaScript 代码在浏览器中运行——例如,V8 在 Chrome 内部。或者,Dart 代码可以编译为 WebAssembly。
Dart Web 包含三种编译模式
- 一个增量 JavaScript 开发编译器,可实现快速的开发者周期。
- 一个优化的 JavaScript 生产编译器,它将 Dart 代码编译为快速、紧凑、可部署的 JavaScript。这些效率来自诸如死代码消除等技术。
- 一个优化的 WebAssembly (WasmGC) 生产编译器,它将 Dart 代码编译为超快速、可部署的 WebAssembly GC 代码。
更多信息
Dart 运行时
#无论您使用哪个平台或如何编译代码,执行代码都需要 Dart 运行时。此运行时负责以下关键任务
管理内存:Dart 使用托管内存模型,其中未使用的内存由垃圾回收器 (GC) 回收。
强制执行 Dart 类型系统:尽管 Dart 中的大多数类型检查都是静态的(编译时),但有些类型检查是动态的(运行时)。例如,Dart 运行时通过类型检查和强制转换运算符强制执行动态检查。
管理隔离:Dart 运行时控制主隔离(代码通常在此处运行)以及应用程序创建的任何其他隔离。
在原生平台上,Dart 运行时自动包含在独立的自包含可执行文件中,并且是 dart run
命令提供的 Dart VM 的一部分。
学习 Dart
#您有很多学习 Dart 的选择。以下是我们推荐的几种
- 通过 DartPad(一个基于 Web 的 Dart 代码执行环境)在浏览器中探索 Dart。
- 参加 Dart 语言之旅,它向您展示如何使用每个主要的 Dart 功能。
- 完成 Dart 教程,其中涵盖了使用 Dart 构建命令行应用的基础知识。
- 通过 Dart 专家的广泛在线培训。
- 探索 API 文档,其中描述了 Dart 核心库。
- 阅读关于 Dart 编程的书籍.
除非另有说明,否则本网站上的文档反映了 Dart 3.7.1 版本。页面上次更新于 2025-01-22。 查看源代码 或 报告问题。