Go 语言中如何使用指针

Go 支持指针。指针是一个变量,它存储的是数据在内存中的地址,而不是值本身。

1. 创建指针

Go 中除映射和切片外的所有变量都是值类型。这意味着,如果将一个变量传递给函数,并且想在函数外部对该变量进行修改,则不能直接修改该变量。每当将一个变量发送给函数时,都会传入该变量的一个副本。

如果想修改变量,一般的方法是使用一个指向内存地址的指针,而不是试图修改变量本身。换句话说,可以使用一个指向变量地址的指针,而不是值本身的副本。当向函数传入一个指针时,原始值和函数中使用的值都指向内存的同一地址。因为它们指向内存中的同一个位置,当改变一个值时,另一个值也会跟着改变。

指针也可以用于传递较大的变量。如果有一个很大的结构体,那么应用程序将需要时间和内存来将结构体及其所有字段复制到一个函数中,而如果传递一个指针,函数将只接收结构体的内存地址。内存地址的体积将比结构体小得多,因此应用程序的效率将更高。

相关推荐
i***13241 小时前
Spring BOOT 启动参数
java·spring boot·后端
IT_Octopus1 小时前
(旧)Spring Securit 实现JWT token认证(多平台登录&部分鉴权)
java·后端·spring
kk哥88991 小时前
Spring详解
java·后端·spring
S***26751 小时前
Spring Cloud Gateway 整合Spring Security
java·后端·spring
码事漫谈1 小时前
C++单元测试框架选型与实战速查手册
后端
OneLIMS1 小时前
Windows Server 2022 + IIS + ASP.NET Core 完整可上传大文件的 报错的问题
windows·后端·asp.net
码事漫谈1 小时前
C++ 依赖管理三剑客:vcpkg、Conan、xmake 速查手册
后端
计算机毕设匠心工作室2 小时前
【python大数据毕设实战】青少年抑郁症风险数据分析可视化系统、Hadoop、计算机毕业设计、包括数据爬取、数据分析、数据可视化、机器学习
后端·python
计算机毕设小月哥2 小时前
【Hadoop+Spark+python毕设】智能制造生产效能分析与可视化系统、计算机毕业设计、包括数据爬取、Spark、数据分析、数据可视化、Hadoop
后端·python·mysql
四问四不知2 小时前
Rust语言进阶(结构体)
开发语言·后端·rust