Go 局部变量&全局变量

简介: Go 局部变量&全局变量

局部变量


定义:定义在{}里面的变量为局部变量
作用域:只能在{}里面有效;执行到定义的那句话,开始分配内存空间,离开作用域自动进行释放


  • 局部变量一定是在函数内部声明
  • 在哪个{}内部声明; 执行到定义的那句话,开始分配内存,只能在哪个{}内部访问,离开作用域自动进行释放

看个例子


package main
import "fmt"
func main() {
    //定义在{}里面的变量就是局部变量,只能在{}里面有效
    //执行到定义变量那句话,才开始分配空间,离开作用域自动释放
    //作用域,变量其作用的范围
    if flag := 3; flag == 3 {
        fmt.Println("flag = ", flag)
    }
       //flag = 4   不能在if外面执行 报错:undefined: flag 未定义的标记
}


全局变量


定义:在函数外部的变量称为全局变量
作用域:同一个包内的任何地方


  • 小写,整个包可以访问
  • 大写,跨包可以访问


package constant
var  A = 12123
var B =  map[string]string{}
var c = "xiaoming"
func Init()  {
 A = 1321312
 B["default"] = "default"
}


测试:同一个包可以访问


package constant
import (
 "fmt"
 "testing"
)
func TestGlobal(t *testing.T)  {
 //全局变量声明到函数外部,整个包都可以访问
 //如果全局变量首字母大写,跨包也可以访问.
 fmt.Println(c)
}


执行结果:


=== RUN   TestGlobal
xiaoming
--- PASS: TestGlobal (0.00s)
PASS


测试:跨包访问


package variable
import (
 "fmt"
 //"go/constant"
 "testing"
 "/GoProject/main/gobase/constant"
)
func TestGlobal(t *testing.T) {
 constant.Init()
 fmt.Println(constant.A)
 fmt.Println(constant.B["default"])
 fmt.Println(constant.c) // 会报错
}


注释掉报错那一行,执行结果如下:


=== RUN   TestGlobal
1321312
default
--- PASS: TestGlobal (0.00s)
PASS


全局变量要避免的坑:例如定义了一个全局变量, 然后又使用了 :=  给全局变量赋值, 此时会出现问题。看下面的例子:


package dbops
import (
 "database/sql"
 _ "github.com/go-sql-driver/mysql"
 "log"
)
var (
 dbConn *sql.DB
 err error
)
func init() {
 dbConn, err := sql.Open("mysql","root:000000@tcp(localhost:3306)/server?charset=utf8")
 if err != nil{
  panic(err.Error())
 }
 log.Println(dbConn)
}
func main()  {
 log.Println("查看全局变量dbConn:",dbConn)
}


执行结果如下:


panic: runtime error: invalid memory address or nil pointer dereference [recovered]
 panic: runtime error: invalid memory address or nil pointer dereference
[signal 0xc0000005 code=0x0 addr=0x0 pc=0x5b0a61]


远远是因为 使用的是 := 对全局变量赋值,结果是全局变量未赋值是个 nil,  init 中的 dConn 使用 := 生成的,这里的 dbConn 是局部变量, 全局变量 dbConn 并没有赋值,还是 nil


还有个坑,最近看代码, 发现 全局变量名字一样,然后,在 init 也初始化了, 然后跨包应用这个全局变量时,这个全局变量还是个 nil, 查了半天,才看到全局变量的名字是一样的,但是归属不同的 包 A, B , 包 A 初始化了,但是用的是 包 B 的全局变量的值, 包B 全局变量并没有被初始化!!!!


相关文章
|
存储 缓存 安全
|
1月前
|
存储 安全 Java
【Golang】(4)Go里面的指针如何?函数与方法怎么不一样?带你了解Go不同于其他高级语言的语法
结构体可以存储一组不同类型的数据,是一种符合类型。Go抛弃了类与继承,同时也抛弃了构造方法,刻意弱化了面向对象的功能,Go并非是一个传统OOP的语言,但是Go依旧有着OOP的影子,通过结构体和方法也可以模拟出一个类。
152 1
|
3月前
|
Cloud Native 安全 Java
Go:为云原生而生的高效语言
Go:为云原生而生的高效语言
286 1
|
9月前
|
编译器 Go
揭秘 Go 语言中空结构体的强大用法
Go 语言中的空结构体 `struct{}` 不包含任何字段,不占用内存空间。它在实际编程中有多种典型用法:1) 结合 map 实现集合(set)类型;2) 与 channel 搭配用于信号通知;3) 申请超大容量的 Slice 和 Array 以节省内存;4) 作为接口实现时明确表示不关注值。此外,需要注意的是,空结构体作为字段时可能会因内存对齐原因占用额外空间。建议将空结构体放在外层结构体的第一个字段以优化内存使用。
|
9月前
|
运维 监控 算法
监控局域网其他电脑:Go 语言迪杰斯特拉算法的高效应用
在信息化时代,监控局域网成为网络管理与安全防护的关键需求。本文探讨了迪杰斯特拉(Dijkstra)算法在监控局域网中的应用,通过计算最短路径优化数据传输和故障检测。文中提供了使用Go语言实现的代码例程,展示了如何高效地进行网络监控,确保局域网的稳定运行和数据安全。迪杰斯特拉算法能减少传输延迟和带宽消耗,及时发现并处理网络故障,适用于复杂网络环境下的管理和维护。
|
3月前
|
Cloud Native Go API
Go:为云原生而生的高效语言
Go:为云原生而生的高效语言
359 0
|
3月前
|
Cloud Native Java Go
Go:为云原生而生的高效语言
Go:为云原生而生的高效语言
232 0
|
3月前
|
Cloud Native Java 中间件
Go:为云原生而生的高效语言
Go:为云原生而生的高效语言
212 0
|
3月前
|
Cloud Native Java Go
Go:为云原生而生的高效语言
Go:为云原生而生的高效语言
305 0
|
3月前
|
数据采集 Go API
Go语言实战案例:多协程并发下载网页内容
本文是《Go语言100个实战案例 · 网络与并发篇》第6篇,讲解如何使用 Goroutine 和 Channel 实现多协程并发抓取网页内容,提升网络请求效率。通过实战掌握高并发编程技巧,构建爬虫、内容聚合器等工具,涵盖 WaitGroup、超时控制、错误处理等核心知识点。
下一篇
oss云网关配置