举报投诉联系我们 手机版 热门标签 鳄鱼CMS
您的位置:鳄鱼CMS > go 变量作用域 Go 语言变量作用域

go 变量作用域 Go 语言变量作用域

2023-04-22 16:31 Go教程

go 变量作用域 Go 语言变量作用域

go 变量作用域 Go 语言变量作用域

go 变量作用域

作用域为已声明标识符所表示的常量、类型、变量、函数或包在源代码中的作用范围。

Go 语言中变量可以在三个地方声明:

  • 函数内定义的变量称为局部变量
  • 函数外定义的变量称为全局变量
  • 函数定义中的变量称为形式参数

接下来让我们具体了解局部变量、全局变量和形式参数。


局部变量

在函数体内声明的变量称之为局部变量,它们的作用域只在函数体内,参数和返回值变量也是局部变量。

以下实例中 main() 函数使用了局部变量 a, b, c:

package main

import "fmt"

func main() {
   
   var a, b, c int 

   
   a = 10
   b = 20
   c = a + b

   fmt.Printf ("结果: a = %d, b = %d and c = %dn", a, b, c)
}

以上实例执行输出结果为:

结果: a = 10, b = 20 and c = 30

全局变量

在函数体外声明的变量称之为全局变量,全局变量可以在整个包甚至外部包(被导出后)使用。

全局变量可以在任何函数中使用,以下实例演示了如何使用全局变量:

package main

import "fmt"


var g int

func main() {

   
   var a, b int

   
   a = 10
   b = 20
   g = a + b

   fmt.Printf("结果: a = %d, b = %d and g = %dn", a, b, g)
}

以上实例执行输出结果为:

结果: a = 10, b = 20 and g = 30

Go 语言程序中全局变量与局部变量名称可以相同,但是函数内的局部变量会被优先考虑。实例如下:

package main

import "fmt"


var g int = 20

func main() {
   
   var g int = 10

   fmt.Printf ("结果: g = %dn",  g)
}

以上实例执行输出结果为:

结果: g = 10

形式参数

形式参数会作为函数的局部变量来使用。实例如下:

package main

import "fmt"


var a int = 20

func main() {
   
   var a int = 10
   var b int = 20
   var c int = 0

   fmt.Printf("main()函数中 a = %dn",  a)
   c = sum( a, b);
   fmt.Printf("main()函数中 c = %dn",  c)
}


func sum(a, b int) int {
   fmt.Printf("sum() 函数中 a = %dn",  a)
   fmt.Printf("sum() 函数中 b = %dn",  b)

   return a + b
}

以上实例执行输出结果为:

main()函数中 a = 10
sum() 函数中 a = 10
sum() 函数中 b = 20
main()函数中 c = 30

初始化局部和全局变量

不同类型的局部和全局变量默认值为:

数据类型 初始化默认值
int 0
float32 0
pointer nil


阅读全文
以上是鳄鱼CMS为你收集整理的go 变量作用域 Go 语言变量作用域全部内容。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。
相关文章
  • go语言数组和切片的区别 Go 语言数组

    go语言数组和切片的区别 Go 语言数组

    2023-04-03 Go教程

    Go 语言提供了数组类型的数据结构。 数组是具有相同唯一类型的一组已编号且长度固定的数据项序列,这种类型可以是任意的原始类型...

  •  Vant4 useEventListener

    Vant4 useEventListener

    2023-03-28 Vant4

    介绍方便地进行事件绑定,在组件​mounted​和​activated​时绑定事件,​unmounted​和​deactivated​时解绑事件。代码演示基...

  • element导航菜单的处理 Element-React NavMenu 导航菜单

    element导航菜单的处理 Element-React NavMenu 导航菜单

    2023-04-11

    为网站提供导航功能的菜单。顶栏适用广泛的基础用法。render() {return (divMenu theme="dark" defaultActive="1" className="el...

  •  Element-React Tooltip 文字提示

    Element-React Tooltip 文字提示

    2023-04-12

    常用于展示鼠标 hover 时的提示信息。基础用法在这里我们提供 9 种不同方向的展示方式,可以通过以下完整示例来理解,选择你要的...

  •  ElementPlus Affix 固钉

    ElementPlus Affix 固钉

    2023-04-27

    Affix 固钉将页面元素固定在特定可视区域。基本用法固钉默认固定在页面顶部。通过设置offset属性来改变吸顶距离,默认值为 0。te...

© 2024 鳄鱼CMS eyucms.com 版权所有 联系我们