go语言的指针变量 go语言指针变量和普通变量的区别( 二 )


官方描述(片段)
即切片是一个抽象层,底层是对数组的引用 。
当我们使用
构建出来的切片的每个位置的值都被赋为interface类型的初始值nil,但是nil值也是有大小的 。
而使用
来进行初始化时 , 虽然生成的切片中不包含nil值,但是无法通过设置的指针变量来完成入队和出队的操作,只能使用append()函数来进行操作
在go语言中,切片是一片连续的内存空间加上长度与容量的标识,比数组更为常用 。使用 append 关键字向切片中追加元素也是常见的切片操作
正是基于此,在使用go语言完成循环队列时 , 首先想到的就是使用make(type, len, cap)关键字方式完成切片初始化,然后使用append()函数来操作该切片,但这一方式出现了很多问题 。在使用append()函数时,切片的cap可能会发生变化,用不好就会发生扩容或收缩 。最终造成的结果是一个四不像的结果 , 入队和出队操作变得与指针变量无关 , 失去了作为循环队列的意义,用在顺序队列还算合适 。
参考博客go语言的指针变量:
Go语言中的Nil
Golang之nil
Go 语言设计与实现
go语言结构体变量和结构体指针变量的区别第二个程序go语言的指针变量,空间都没有分配就初始化赋值go语言的指针变量,这根本就是在给系统添乱嘛 。
golang-指针类型 tips: *号,可以指向指针类型内存地址上的值,号,可以获取值类型的内存地址
每一个变量都有内存地址,可以通过变量来操作内存地址中的值,即内存的大小
go语言中获取变量的内存地址方法:通过符号可以获取变量的地址
定义:普通变量存储的是对应类型的值,这些类型就叫值类型
变量b,在内存中的地址为:0x1040a124,在这个内存地址上存储的值为:156
定义:指针类型的变量存储的是?个地址,所以?叫指针类型或引?类型
b 是值类型 , 它指向的是内存地址上的值
a是指针类型,它指向的是b的内存地址
指针类型定义 , 语法: var 变量名 *类型
指针类型在定义完成后 , 默认为空地址,即空指针(nil)
在定义好指针变量后,可以通过***** 符号可以获取指针变量指向的变量
在这里的 *a 等价于 b,通过修改 *a  , 最终修改的是值类型b的值
这里a,d是值类型,b,c是指针类型
d就相当于把a内存地址上值,在内存中从新开辟了一块空间存储,d和a互不影响
b,c相当于指向了a的内存地址 , 当使用*号引用出内存地址上的变量上,修改值得,a的值也会跟着改变
Go 如何查看一个变量的内存地址 理解指针问题 熟悉C语言的同学都知道go语言的指针变量,查看一个变量的地址在处理指针的相关问题的时候直观重要go语言的指针变量 , 在C中直接取地址符 即可 。那么在Go语言中如何查看一个变量的地址go语言的指针变量,go语言的指针变量我们使用unsafe.Pointer() 函数来查看一个变量的内存地址 。
举例go语言的指针变量:
type Vertex struct {
X, Y float64
}
func (v Vertex) sqrt() float64 {
return math.Sqrt(v.X * v.X + v.Y * v.Y)
}
func (vVertex) scale(f float64) { //带 号 和不带*号的区别 可以从内存地址来看出
fmt.printf("=======", unsafe.Pointer(v))//v 本身就是指针 存储的就是地址 不用取地址
v.X = x.X * f
v.Y = v.Y * f
}
func main() {
v := Vertex{3, 4}
fmt.printf("=======", unsafe.Pointer(v))
v.scale(10)
fmt.Println(v.sqrt())
}
//带 号 打印的结果 ====== -%!(EXTRA unsafe.Pointer=0xc00006e070)======%!(EXTRA unsafe.Pointer=0xc00006e070) 相同

推荐阅读