登录
首页 >  数据库 >  MySQL

为什么在函数中修改指针变量的值,函数外部却无法获取到修改后的值?

时间:2024-10-26 22:15:54 424浏览 收藏

各位小伙伴们,大家好呀!看看今天我又给各位带来了什么文章?本文标题《为什么在函数中修改指针变量的值,函数外部却无法获取到修改后的值?》,很明显是关于数据库的文章哈哈哈,其中内容主要会涉及到等等,如果能帮到你,觉得很不错的话,欢迎各位多多点评和分享!

为什么在函数中修改指针变量的值,函数外部却无法获取到修改后的值?

为什么指针值无法在函数外更改?

如给定代码所示,我们在 initdb 函数中对指针变量赋值,但 main 函数中打印时仍然显示为 nil。

原因:

在 go 语言中,局部变量会覆盖参数变量,即使这两个变量同名。initdb 函数中声明的局部变量 db 是一个新的变量,它覆盖了作为参数传入的 db。

当对局部变量 db 赋值时,它并不影响函数参数 db 的值。因此,main 函数打印时获取的是参数 db 的值,也就是 nil。

解决方案:

要更改传递给函数的指针变量的值,可以使用指针的解引用符号 *。具体如下:

func initDB(db **sql.DB) {
    // 使用 *db 来解引用指针并对其值进行操作
    *db, err = sql.Open("mysql", "root:123456@tcp(127.0.0.1:3306)/data")
    checkErr(err)
}

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于数据库的相关知识,也可关注golang学习网公众号。

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>