在写一个关于session的小程序时,定义了一个包内全局变量,编译的时候没有报错,但是一旦运行函数就报runtime error: invalid memory address or nil pointer dereference;开始各种找bug.........
刚开始以为是调用的包内出现有问题,所以先打印的是包内可能出现问题的地方,还是报错,直到直接把包内函数都返回了nil,结果还是有问题;才反应过来是调用的地方存在问题;还是经验少的锅啊。。。出问题要从源头一点点的抽丝剥茧。
打印出来后才发现是在init()里给globaSessions初始化是,误用了':=',这样导致globalSessions此时变成了局部变量,并不能更改全局变量值,因此在调用的时候就会出现错误了;谨记!解决问题时参考处,感谢~点击打开链接
错误示例:
var globalSessions *sessiontest.Manager
func init() {
globalSessions, _ := sessiontest.NewManager("memory", "gosessionid", 3600)
if globalSessions == nil {
panic("global sessions create err")
}
fmt.Println("global",globalSessions)
}
正确示例:
var globalSessions *sessiontest.Manager
func init() {
globalSessions, _ = sessiontest.NewManager("memory", "gosessionid", 3600)
if globalSessions == nil {
panic("global sessions create err")
}
fmt.Println("global",globalSessions)
}