本文介绍: 函数基础知识以及函数的特点和函数的使用

目录

函数

函数特点

函数的使用

函数定义

函数的参数

函数的返回值

函数的变量作用域

函数的递归调用

函数的可变参数

函数的闭包

函数的 defer 语句

注意


函数

函数调用:函数调用需要传递函数定义中要求的参数,并根据需要接收返回值

匿名函数:匿名函数没有函数名,可以直接定义调用。常用于函数内部作为闭包使用

闭包:闭包是指一个函数内部定义的函数,它可以访问外部函数的变量,并将这些变量与函数绑定,形成一个闭合的环境

可变参数使用 ... 表示可变参数,可变参数必须放在函数参数列表最后面,并且只能有一个

函数作为参数:可以将函数作为参数传递给其他函数,这种函数称为高阶函数。常用于函数式编程中。

函数作为返回值:函数也可以作为返回值,这种函数称为闭包。常用于实现类似于装饰器或者切面等功能

函数特点

1.函数可以有多个返回值

2.可以将函数作为参数传递给其他函数。

3.可以定义匿名函数。

4.支持闭包。

5.函数可以有多个参数和多个返回值

6.可以使用可变参数。

函数的使用

函数定义

Go语言中函数的定义使用 func 关键字,其基本语法格式如下

func 函数名(参数列表) (返回值列表) {
    函数体
}

其中:

例如,下面是一个计算两个整数之和的函数:

func Add(x, y int) int {
    return x + y
}

上述函数名为 Add,有两个参数 xy类型都为 int返回值类型为 int,函数体内部实现为将 xy 相加,并将结果返回。

函数的参数

函数可以有多个参数,参数的类型放在参数名的后面,如果两个或多个连续的参数的类型相同,则可以省略类型,例如:

func swap(x, y string) (string, string) {
   return y, x
}

函数的返回值

函数可以返回多个值,这些值用括号括起来并用逗号分隔。例如:

func sum(a int, b int) (int, int) {
   return a+b, a-b
}

可以使用 := 赋值语句调用函数,并自动推断返回值类型:

a, b := sum(1, 2)

函数的参数是值传递,在函数调用时,传递的是实参的副本

函数的变量作用域

数中声明变量作用域是该函数内部,在函数外部是不可见的。如果函数中使用全局变量,则在函数中可以直接使用

函数的递归调用

函数可以递归调用递归调用必须有一个终止条件。例如:

func factorial(n uint64) (result uint64) {
   if (n > 0) {
      result = n * factorial(n-1)
      return result
   }
   return 1
}

函数的可变参数

函数的可变参数是一个非常有用的特性,可以接受任意数量的参数。在参数列表的最后一个参数之前加上省略号 ... 即可

func sum(numbers ...int) int {
   total := 0
   for _, number := range numbers {
      total += number
   }
   return total
}

函数的闭包

函数的闭包是指函数可以访问外部作用域中的变量。例如:

func main() {
   nextInt := intSeq()

   fmt.Println(nextInt())
   fmt.Println(nextInt())
   fmt.Println(nextInt())

   newInts := intSeq()
   fmt.Println(newInts())
}

func intSeq() func() int {
   i := 0
   return func() int {
      i += 1
      return i
   }
}

以上代码输出

1
2
3
1

函数的 defer 语句

在Go语言中,函数的 defer 语句可以在函数返回时执行一些清理工作,如关闭文件解锁资源等。defer 语句可以被插入到函数的任意位置,并且可以定义多个 defer 语句。在函数执行时,每个 defer 语句都会被压入一个栈中,等待函数返回时逆序执行。

func main() {
    defer fmt.Println("deferred")
    fmt.Println("regular")
}

这个程序输出

regular
deferred

在这个例子中,当 main 函数执行到 defer 语句时,”deferred” 被压入一个栈中。然后程序继续执行,输出regular“。当函数返回时,栈中的 defer 语句逆序执行,最后输出deferred“。

除了可以用来清理资源defer 语句还可以用来记录函数的执行时间。下面是一个例子

func timeTrack(start time.Time, name string) {
    elapsed := time.Since(start)
    log.Printf("%s took %s", name, elapsed)
}

func myFunc() {
    defer timeTrack(time.Now(), "myFunc")
    // 函数的实际代码
}

在这个例子中,timeTrack 函数用来记录函数的执行时间。在 myFunc 函数中,defer 语句被用来调用 timeTrack 函数,并传入当前时间和函数名作为参数。当 myFunc 函数返回时,timeTrack 函数被执行,输出函数的执行时间。

注意

原文地址:https://blog.csdn.net/weixin_71646897/article/details/130693715

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_29012.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注