您的位置:首页 > 编程语言 > Go语言

go语言中指针详解

2020-01-14 14:03 190 查看

指针在Go语言中几个特点:

(1)类型指针,允许对这个指针类型的数据进行修改,传递数据可以直接使用指针,而无须拷贝数据,类型指针不能进行偏移和运算。
(2)切片,由指向起始元素的原始指针、元素数量和容量组成。
(3)每个变量在运行时都拥有一个地址,这个地址代表变量在内存中的位置。Go语言中使用在变量名前面添加&操作符(前缀)来获取变量的内存地址(取地址操作),格式如下:

ptr := &v      //ptr即表示变量v的内存地址

若v的类型为T, ptr的类型为*T,称作T的指针类型,*代表指针

指针的实例运用:


运行结果:

0xc00000a0c8
0xc0000421f0

变量、指针和地址三者的关系是,每个变量都拥有地址,指针的值就是地址。

使用指针修改值:

在go语言中函数中得参数传递是值传递而不是引用传递,要实现参数得引用传递需要通过指针修改值来实现。

运行结果: 2 1

创建指针的另一种方法——new() 函数

Go 语言还提供了另外一种方法来创建指针变量,格式如下:

new(类型)

一般这样写:

str := new(string)
*str = "ninja"
fmt.Println(*str)

new() 函数可以创建一个对应类型的指针,创建过程会分配内存。被创建的指针指向的值为默认值。

  • 点赞
  • 收藏
  • 分享
  • 文章举报
Hzy_han 发布了31 篇原创文章 · 获赞 8 · 访问量 1135 私信 关注
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: