:bowtie: 难死我了
+ `r := [...]int{99: -1}`
这行代码 解释是 ** 定义了一个含有100个元素的数组r,最后一个元素被初始化为-1,其它元素都是用0初始化。 **
+ **当调用一个函数的时候,函数的每个调用参数将会被赋值给函数内部的参数变量,所以函数参数变量接收的是一个复制的副本,并不是原始调用的变量。因为函数参数传递的机制导致传递大的数组类型将是低效的,并且对数组参数的任何的修改都是发生在复制的数组上,并不能直接修改调用时原始的数组变量。在这个方面,Go语言对待数组的方式和其它很多编程语言不同,其它编程语言可能会隐式地将数组作为引用或指针对象传入被调用的函数。
当然,我们可以显式地传入一个数组指针,那样的话函数通过指针对数组的任何修改都可以直接反馈到调用者。下面的函数用于给
[32]byte类型的数组清零:**
```
func zero(ptr *[32]byte) {
for i := range ptr {
ptr[i] = 0
}
}
```
+ `make([]T, len)`
`make([]T, len, cap) // same as make([]T, cap)[:len]`
+ ** 一个命名为S的结构体类型将不能再包含S类型的成员:因为一个聚合的值不能包含它自身。(该限制同样适应于数组。)但是S类型的结构体可以包含*S指针类型的成员,这可以让我们创建递归的数据结构,比如链表和树结构等。**
+ **在Go中,函数被看作第一类值(first-class values):函数像其他值一样,拥有类型,可以被赋值给其他变量,传递给函数,从函数返回。对函数值(function value)的调用类似函数调用。**
```
func square(n int) int { return n * n }
func negative(n int) int { return -n }
func product(m, n int) int { return m * n }
f := square
fmt.Println(f(3)) // "9"
f = negative
fmt.Println(f(3)) // "-3"
fmt.Printf("%T\n", f) // "func(int) int"
f = product // compile error: can't assign func(int, int) int to func(int) int
```
+ 基于指针对象的方法
!(go圣经地址,好晕呢)[https://books.studygolang.com/gopl-zh/ch6/ch6-02.html]
有疑问加站长微信联系(非本文作者)