链客,专为开发者而生,有问必答!
此文章来自区块链技术社区,未经允许拒绝转载。
Go 语言中指针是很容易学习的,Go 语言中使用指针可以更简单的执行一些任务。
接下来让我们来一步步学习 Go 语言指针。
我们都知道,变量是一种使用方便的占位符,用于引用计算机内存地址。
Go 语言的取地址符是 &,放到一个变量前使用就会返回相应变量的内存地址。
以下实例演示了变量在内存中地址:
package mainimport "fmt"func main() {
var a int = 10
fmt.Printf("变量的地址: %xn", &a )}
执行以上代码输出结果为:
变量的地址: 20818a220
现在我们已经了解了什么是内存地址和如何去访问它。接下来我们将具体介绍指针。
什么是指针
一个指针变量可以指向任何一个值的内存地址它指向那个值的内存地址。
类似于变量和常量,在使用指针前你需要声明指针。指针声明格式如下:
var var_name *var-type
var-type 为指针类型,var_name 为指针变量名,* 号用于指定变量是作为一个指针。以下是有效的指针声明:
var ip int / 指向整型/var fp float32 / 指向浮点型 /
本例中这是一个指向 int 和 float32 的指针。
如何使用指针
指针使用流程:
定义指针变量。
为指针变量赋值。
访问指针变量中指向地址的值。
在指针类型前面加上 * 号(前缀)来获取指针所指向的内容。
package mainimport "fmt"func main() {
var a int= 20 / 声明实际变量 /
var ip int / 声明指针变量 */
ip = &a / 指针变量的存储地址 /
fmt.Printf("a 变量的地址是: %xn", &a )
/ 指针变量的存储地址 /
fmt.Printf("ip 变量的存储地址: %xn", ip )
/ 使用指针访问值 /
fmt.Printf("ip 变量的值: %dn", ip )}
以上实例执行输出结果为:
a 变量的地址是: 20818a220ip 变量的存储地址: 20818a220*ip 变量的值: 20
Go 空指针
当一个指针被定义后没有分配到任何变量时,它的值为 nil。
nil 指针也称为空指针。
nil在概念上和其它语言的null、None、nil、NULL一样,都指代零值或空值。
一个指针变量通常缩写为 ptr。
查看以下实例:
package mainimport "fmt"func main() {
var ptr *int
fmt.Printf("ptr 的值为 : %xn", ptr )}
以上实例输出结果为:
ptr 的值为 : 0
空指针判断:
if(ptr != nil) / ptr 不是空指针 /if(ptr == nil) / ptr 是空指针 /
原文发布于微信公众号 - Golang语言社区(Golangweb)
原文发表时间:2016-07-19
本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。
发表于 2018-03-22
Go
举报
12
0
分享
扫描二维码
Golang语言社区
1782 篇文章382 人订阅
订阅专栏
Go 语言函数
Go 语言结构
Go 语言常量
Go 语言指针作为函数参数
Go 错误处理
有疑问加站长微信联系(非本文作者)