2016-02-15 03:06:34 +00:00
|
|
|
|
### 2.4.2. 可赋值性
|
2015-12-09 07:45:11 +00:00
|
|
|
|
|
2016-04-04 11:50:06 +00:00
|
|
|
|
赋值语句是显式的赋值形式,但是程序中还有很多地方会发生隐式的赋值行为:函数调用会隐式地将调用参数的值赋值给函数的参数变量,一个返回语句会隐式地将返回操作的值赋值给结果变量,一个复合类型的字面量(§4.2)也会产生赋值行为。例如下面的语句:
|
2015-12-09 07:45:11 +00:00
|
|
|
|
|
|
|
|
|
```Go
|
2016-04-04 11:50:06 +00:00
|
|
|
|
medals := []string{"gold", "silver", "bronze"}
|
2015-12-09 07:45:11 +00:00
|
|
|
|
```
|
|
|
|
|
|
2016-02-15 03:06:34 +00:00
|
|
|
|
隐式地对slice的每个元素进行赋值操作,类似这样写的行为:
|
2015-12-09 07:45:11 +00:00
|
|
|
|
|
|
|
|
|
```Go
|
2016-04-04 11:50:06 +00:00
|
|
|
|
medals[0] = "gold"
|
|
|
|
|
medals[1] = "silver"
|
|
|
|
|
medals[2] = "bronze"
|
2015-12-09 07:45:11 +00:00
|
|
|
|
```
|
|
|
|
|
|
2016-02-15 03:06:34 +00:00
|
|
|
|
map和chan的元素,虽然不是普通的变量,但是也有类似的隐式赋值行为。
|
2015-12-09 07:45:11 +00:00
|
|
|
|
|
2016-02-15 03:06:34 +00:00
|
|
|
|
不管是隐式还是显式地赋值,在赋值语句左边的变量和右边最终的求到的值必须有相同的数据类型。更直白地说,只有右边的值对于左边的变量是可赋值的,赋值语句才是允许的。
|
2015-12-09 07:45:11 +00:00
|
|
|
|
|
2016-02-15 03:06:34 +00:00
|
|
|
|
可赋值性的规则对于不同类型有着不同要求,对每个新类型特殊的地方我们会专门解释。对于目前我们已经讨论过的类型,它的规则是简单的:类型必须完全匹配,nil可以赋值给任何指针或引用类型的变量。常量(§3.6)则有更灵活的赋值规则,因为这样可以避免不必要的显式的类型转换。
|
2015-12-09 07:45:11 +00:00
|
|
|
|
|
2016-04-04 11:50:06 +00:00
|
|
|
|
对于两个值是否可以用`==`或`!=`进行相等比较的能力也和可赋值能力有关系:对于任何类型的值的相等比较,第二个值必须是对第一个值类型对应的变量是可赋值的,反之亦然。和前面一样,我们会对每个新类型比较特殊的地方做专门的解释。
|