golang中的左值VS右值
左值 | 可寻址 |
右值 | 不可寻址 |
可寻址:可以通过&取地址符,获取内存地址; 可寻址,也就是分配了内存;
不可寻址:根本没有分配内存;
常量const
常量通常只支持数字/字符串/布尔,以及他们的表达式,还有通过type定义的以这些基本类型封装的类型.
为什么只有这几个基本类型呢?
因为常量属于在编译器就确定取值了,正好数字/字符串/布尔,可以满足需求;
而向数组,切片,结构体等其他需要在运行期通过分配内存或执行若干运算才能确定值;
所以:不可寻址的情况
规则一: 常量值是右值,在编译器就取值了,不用分配内存空间了,所以不可取值.
规则二: 函数的返回值,是没有分配内存空间,所以不可直接取值;
规则三: 字面量:
3.1 简单字面量直接在编译器取值,所以不可寻址的;
3.2 复合字面量需要在运行期先分配内存空间再确定值,所以是可寻址的; 但golang中针对符合字面量不支持自动取地址(报错:S{}.read()),所以在调用结构体的方法时候,还需要手动显示的取地址((&S{}).read()). so 导致值接收者的方法集比引用接收者的方法集小.
规则四:切片操作也是不可寻址,不占内存,这是便宜的
arr := [5]int{1, 2, 3, 4, 5}
fmt.Println(&arr[2:3:5]) //报错:cannot take the address of arr[2:3:5]