当前位置: 首页 > news >正文

【成长纪实】Dart 与 ArkTS 函数与类的对比学习:从 Flutter 到 HarmonyOS

Dart 和 ArkTS 都是现代、响应式的语言,分别作为 Flutter 和 HarmonyOS 应用开发的核心。它们在语法上颇有相似之处(都受到 C++、Java、JavaScript/TypeScript 家族的影响),但在设计哲学和具体实现上又各有侧重。理解它们在函数和类上的差异,是高效进行跨平台学习的关键。

一、 函数对比

1. 基本函数定义

  • Dart: 类型注解是可选的,但推荐使用。返回值类型、参数类型都可以省略(此时为 dynamic)。

    dart

    // Dart
    int add(int a, int b) {return a + b;
    }// 类型省略版本 (不推荐在生产环境使用)
    add(a, b) {return a + b;
    }
  • ArkTS: 作为 TypeScript 的超集,类型是强制的。这提供了更好的静态检查和开发体验。

    typescript

    // ArkTS
    add(a: number, b: number): number {return a + b;
    }

2. 箭头函数 (Lambda/匿名函数)

  • Dart: 对于只有一个表达式的函数,可以使用箭头语法 =>。它隐含了 return

    dart

    // Dart
    int add(int a, int b) => a + b;
    var list = [1, 2, 3];
    var doubled = list.map((e) => e * 2).toList();
  • ArkTS: 同样支持箭头函数,语法与 JavaScript/TS 一致。

    typescript

    // ArkTS
    const add = (a: number, b: number): number => a + b;
    let list: number[] = [1, 2, 3];
    let doubled = list.map((e: number) => e * 2);

3. 参数类型

可选参数与默认参数:

  • Dart: 提供了两种可选参数机制。

    • 命名可选参数: 使用 {} 包裹,调用时使用 paramName: value 的形式。

      dart

      // Dart
      void introduce({String name = '匿名', int age = 0}) {print('我是$name, 今年$age岁。');
      }
      introduce(name: '张三', age: 20); // 调用
      introduce(age: 25); // 调用
    • 位置可选参数: 使用 [] 包裹,按顺序传递。

      dart

      // Dart
      void introduce(String name, [int age = 0]) {print('我是$name, 今年$age岁。');
      }
      introduce('李四', 30); // 调用
      introduce('王五'); // 调用
  • ArkTS: 语法更接近 TypeScript,使用 ? 标识可选参数,并可直接在参数列表中赋默认值。

    typescript

    // ArkTS
    introduce(name: string = '匿名', age?: number): void {console.log(`我是${name}, 今年${age}岁。`);
    }
    introduce('张三', 20); // 调用
    introduce('李四'); // 调用,age 为 undefined

4. 异步函数

  • Dart: 使用 async/await 关键字。异步函数返回 Future<T> 类型。

    dart

    // Dart
    Future<int> fetchUserData() async {// 模拟网络请求await Future.delayed(Duration(seconds: 1));return 42;
    }void main() async {var data = await fetchUserData();print(data); // 输出: 42
    }
  • ArkTS: 同样使用 async/await,但返回类型是 Promise<T>

    typescript

    // ArkTS
    async fetchUserData(): Promise<number> {// 模拟网络请求await new Promise(resolve => setTimeout(resolve, 1000));return 42;
    }async function main() {let data = await fetchUserData();console.log(data); // 输出: 42
    }

二、 类对比

1. 基本类定义与构造函数

  • Dart: 构造函数可以有多种形式。this. 语法用于简化参数赋值。

    dart

    // Dart
    class Person {String name;int age;// 标准构造函数Person(this.name, this.age);// 命名构造函数Person.newBorn() {name = '新生儿';age = 0;}// 方法void introduce() {print('我是$name, 今年$age岁。');}
    }
  • ArkTS: 使用 constructor 关键字定义构造函数。属性通常在构造函数参数中直接声明。

    typescript

    // ArkTS
    class Person {name: string;age: number;// 构造函数constructor(name: string, age: number) {this.name = name;this.age = age;}// 方法introduce(): void {console.log(`我是${this.name}, 今年${this.age}岁。`);}
    }

2. 继承

  • Dart: 使用 extends 继承,使用 super 调用父类构造函数和方法。

    dart

    // Dart
    class Student extends Person {String major;Student(String name, int age, this.major) : super(name, age);@overridevoid introduce() {super.introduce(); // 调用父类方法print('我的专业是$major。');}
    }
  • ArkTS: 同样使用 extends 和 super

    typescript

    // ArkTS
    class Student extends Person {major: string;constructor(name: string, age: number, major: string) {super(name, age); // 必须首先调用 superthis.major = major;}override introduce(): void {super.introduce(); // 调用父类方法console.log(`我的专业是${this.major}。`);}
    }

3. 访问控制符 (封装)

  • Dart: 没有 publicprivateprotected 关键字。默认都是公共的。以一个下划线 _ 开头的标识符是库私有的。

    dart

    // Dart
    class BankAccount {String _privateData; // 库内可见String publicData; // 到处可见void _privateMethod() {} // 库内可见
    }
  • ArkTS: 提供了标准的访问控制符,与 Java/C# 类似。

    • public (默认): 公有。

    • private: 私有,以 # 开头  使用 private 关键字(具体取决于TS配置,HarmonyOS推荐使用 private)。

    • protected: 受保护,子类和自身可访问。

    typescript

    // ArkTS
    class BankAccount {private balance: number = 0; // 私有属性public owner: string; // 公有属性public deposit(amount: number): void {this.balance += amount; // 类内部可以访问私有属性}public getBalance(): number {return this.balance;}
    }

4. 计算属性

  • Dart: 使用 get 关键字定义计算属性。

    dart

    // Dart
    class Rectangle {double width, height;Rectangle(this.width, this.height);// 计算属性 areadouble get area => width * height;set area(double value) { // 也可以有 setterwidth = value / height;}
    }
  • ArkTS: 使用 get 关键字,语法略有不同。

    typescript

    // ArkTS
    class Rectangle {width: number;height: number;constructor(width: number, height: number) {this.width = width;this.height = height;}// 计算属性 areaget area(): number {return this.width * this.height;}
    }

三、 总结与核心差异表
特性DartArkTS核心差异
函数类型可选,动态类型强制,静态类型ArkTS 的类型系统更严格,旨在减少运行时错误。
可选参数命名参数 {},位置参数 []使用 ? 和默认值语法风格不同,Dart 的命名参数在调用时更清晰。
异步返回Future<T>Promise<T>概念完全相同,只是类型名称不同。
构造函数与类同名,this. 语法糖constructor 关键字Dart 的语法更简洁。
访问控制下划线 _ 前缀表示库私有publicprivateprotected 关键字ArkTS 提供了更传统和精细的访问控制。
空安全默认开启,非空类型需初始化继承 TypeScript 的严格空检查两者都致力于在编译时消除空引用错误。
设计哲学为 Flutter 的 UI-as-Code 优化,灵活为大型应用和系统级开发优化,严谨Dart 偏向灵活性开发效率,ArkTS 偏向工程化运行时安全

学习建议:

  • 从 Dart 到 ArkTS: 你需要重点适应强制的类型注解、传统的访问控制符以及 constructor 关键字。忘掉 Dart 的 _ 私有方式。

  • 从 ArkTS 到 Dart: 你会感受到更自由的语法(类型可选),并学习 Dart 特有的命名构造函数和 _ 私有规则。注意 Future 和 Promise 的转换。

希望这篇对比能帮助你在 Dart 和 ArkTS 的世界里自如切换,更好地驾驭 Flutter 和 HarmonyOS 应用开发!

https://developer.huawei.com/consumer/cn/training/classDetail/fd34ff9286174e848d34cde7f512ce22?type=1%3Fha_source%3Dhmosclass&ha_sourceId=89000248

http://www.dtcms.com/a/502966.html

相关文章:

  • 基于 JETSON+FPGA+GMSL+AI 车载视频采集与存储系统设计(二)系统测试
  • Flutter Event Loop
  • LeetCode 1287.有序数组中出现次数超过25%的元素
  • 递归-50.Pow(x,n)-力扣(LeetCode)
  • Flutter 并发编程全解:从零掌握 Isolate
  • 跨网络互联技术(①Singbox Core-Flutter-Android)
  • 移动端网站的重要性做一款推荐类的网站
  • 用div做网站中间部分做网站是干啥的
  • 【思维导图SimpleMind Pro】SimpleMind Pro——轻量级思维导图软件完全指南:轻量专业,让思维高效可视化
  • jlink烧入软件的使用
  • 03-流程控制语句-教程
  • 【mqtt参数上云和小程序开发】【第5期】hcsr04超声波测距模块调试完成
  • 【STM32笔记】:P03 ISP 一键下载电路详解
  • 江苏省网站建设哪家好php做的购物网站
  • 常见的位运算的总结
  • CSRF(跨站请求伪造)攻击详解:原理、途径与防范
  • 【C++】使用双指针算法习题
  • 全能型 AI 模型新标杆 Qwen2.5-Omni
  • 建设银行佛山分行网站wordpress插件 评分
  • 大数据计算引擎-从源码看Spark AQE对于倾斜的处理
  • 前端基础知识---Ajax
  • 数据结构——多维数组的存储
  • 编译django做的网站网站制作 价格
  • 破解商家客服困局:真人工AI回复如何成为转型核心
  • 【Qt开发】多元素类控件(二)-> QTableWidget
  • 如何建设一个优秀的电商网站自己怎么创建微信公众号
  • 【成长纪实】Flutter中Dart 与Harmony中 ArkTS 异步编程对比:从 Future 到 Promise
  • ARMv7-A 移植 FreeRTOS 栈帧初始化
  • ARMv7-A 移植 FreeRTOS 中断和临界区管理
  • STM32中PB4引脚作普通GPIO使用的一个小问题