博客
关于我
Dart开发之——函数
阅读量:100 次
发布时间:2019-02-26

本文共 1485 字,大约阅读时间需要 4 分钟。

Dart语言函数概述

1. 概述

Dart语言中的函数机制是其核心特性之一。本文将从以下几个方面探讨Dart中的函数特点:

  • 主函数(main)
  • 自定义函数
  • 可选参数函数
  • 匿名函数
  • 闭包

2. 主函数(main)

2.1 定义

main函数是Dart程序的入口点,通常用于处理命令行参数。它的特点是没有返回值,且省略了参数类型的声明。

2.2 完整示例

void main(List
args) { print(args);}

在程序参数处输入1,2,3即可运行并查看输出结果。

3. 自定义函数

3.1 定义特点

  • 自定义函数用于为特定功能命名。
  • 返回值和参数类型在定义时可以省略。
  • 只有一行代码的函数可以使用双箭头代替返回语句。
  • 函数格式应遵循:
返回值 函数名(参数){ 函数体 }

3.2 常见示例

main() {    var result = addFunction(1, 1);    print(result);}int addFunction(int a, int b) {    return a + b;}

同样,可以省略返回值和参数类型:

addFunction(a, b) {    return a + b;}

或使用双箭头:

addFunction(a, b) => a + b;

4. 可选参数函数

4.1 参数类型

Dart中的可选参数分为名称可选参数位置可选参数

  • 名称可选参数:参数列表放在大括号中,需使用required修饰,参数顺序不重要。
  • 位置可选参数:参数放在中括号中。

4.2 名称可选参数示例

main() {    myFunc(age: 18, name: "张三");}myFunc({required String name, required int age}) {    if (name != null) {        print("名字是:$name");    }    if (age != null) {        print("年龄是:$age");    }}

4.3 位置可选参数示例

main() {    myFunc2("张三");}myFunc2(String name, [int? age]) {    if (name != null) {        print("名字是:$name");    }    if (age != null) {        print("年龄是:$age");    }}

5. 匿名函数

5.1 定义特点

匿名函数没有名字,可直接赋值或调用。

5.2 示例

main() {    // 先赋值再调用    var res = func(1, 2);    print(res);    // 直接调用    (a, b) {         return a + b;     }(1, 2);}var func = (a, b) {     return a + b; };

6. 闭包

6.1 说明

闭包是一种函数对象,能够记住其所在的作用域。

6.2 示例

main() {    var package = func("张三");    print(package());}func(name) {    return () => "Hello $name";}

6.3 说明

  • 参数name仅在func内部使用,超出作用域后将失效。
  • func返回一个匿名函数(闭包),用于访问name的值。

转载地址:http://ovkk.baihongyu.com/

你可能感兴趣的文章
NoClassDefFoundError: org/springframework/boot/context/properties/ConfigurationBeanFactoryMetadata
查看>>
Node JS: < 一> 初识Node JS
查看>>
Node Sass does not yet support your current environment: Windows 64-bit with Unsupported runtime(72)
查看>>
Node-RED中使用JSON数据建立web网站
查看>>
Node-RED中使用json节点解析JSON数据
查看>>
Node-RED中使用node-random节点来实现随机数在折线图中显示
查看>>
Node-RED中使用node-red-browser-utils节点实现选择Windows操作系统中的文件并实现图片预览
查看>>
Node-RED中使用node-red-contrib-image-output节点实现图片预览
查看>>
Node-RED中使用node-red-node-ui-iframe节点实现内嵌iframe访问其他网站的效果
查看>>
Node-RED中使用Notification元件显示警告讯息框(温度过高提示)
查看>>
Node-RED中实现HTML表单提交和获取提交的内容
查看>>
Node-RED中建立Websocket客户端连接
查看>>
Node-RED中通过node-red-ui-webcam节点实现访问摄像头并截取照片预览
查看>>
node-request模块
查看>>
Node.js 8 中的 util.promisify的详解
查看>>
Node.js 函数是什么样的?
查看>>
Node.js 历史
查看>>
Node.js 在个推的微服务实践:基于容器的一站式命令行工具链
查看>>
Node.js 实现类似于.php,.jsp的服务器页面技术,自动路由
查看>>
Node.js 异步模式浅析
查看>>