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

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

一 概述

本文介绍Dart中的函数,涉及一下内容:

  • main函数
  • 自定义函数
  • 可选参数的函数
  • 匿名函数
  • 闭包

二 main函数

2.1 说明

  • main是整个程序的入口
  • 我们常见的main是省去了返回值,参数的函数

2.2 完整的main函数

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

在Program arguments处传入1,2,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.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.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.1 说明

闭包是一种函数对象作用范围

6.2 示例

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

说明:

  • 参数name只能在func内部使用,出了作用域就会失效
  • func函数返回一个匿名函数,这个匿名函数就是一个闭包

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

你可能感兴趣的文章
mysql中出现update-alternatives: 错误: 候选项路径 /etc/mysql/mysql.cnf 不存在 dpkg: 处理软件包 mysql-server-8.0的解决方法(全)
查看>>
Mysql中各类锁的机制图文详细解析(全)
查看>>
MySQL中地理位置数据扩展geometry的使用心得
查看>>
Mysql中存储引擎简介、修改、查询、选择
查看>>
Mysql中存储过程、存储函数、自定义函数、变量、流程控制语句、光标/游标、定义条件和处理程序的使用示例
查看>>
mysql中实现rownum,对结果进行排序
查看>>
mysql中对于数据库的基本操作
查看>>
Mysql中常用函数的使用示例
查看>>
MySql中怎样使用case-when实现判断查询结果返回
查看>>
Mysql中怎样使用update更新某列的数据减去指定值
查看>>
Mysql中怎样设置指定ip远程访问连接
查看>>
mysql中数据表的基本操作很难嘛,由这个实验来带你从头走一遍
查看>>
Mysql中文乱码问题完美解决方案
查看>>
mysql中的 +号 和 CONCAT(str1,str2,...)
查看>>
Mysql中的 IFNULL 函数的详解
查看>>
mysql中的collate关键字是什么意思?
查看>>
MySql中的concat()相关函数
查看>>
mysql中的concat函数,concat_ws函数,concat_group函数之间的区别
查看>>
MySQL中的count函数
查看>>
MySQL中的DB、DBMS、SQL
查看>>