var a int = 100 var b int = 200 var t int t = a a = b b = t fmt.Println(a, b)在计算机刚发明时,内存非常“精贵”。这种变量交换往往是非常奢侈的。于是计算机“大牛”发明了一些算法来避免使用中间变量:
var a int = 100 var b int = 200 a = a ^ b b = b ^ a a = a ^ b fmt.Println(a, b)这样的算法很多,但是都有一定的数值范围和类型要求。
var a int = 100 var b int = 200 b, a = a, b fmt.Println(a, b)多重赋值时,变量的左值和右值按从左到右的顺序赋值。
type IntSlice []int func (p IntSlice) Len() int { return len(p) } func (p IntSlice) Less(i, j int) bool { return p[i] < p[j] } func (p IntSlice) Swap(i, j int) { p[i], p[j] = p[j], p[i] }代码说明如下:
本文链接:http://task.lmcjl.com/news/14858.html