conn, err = ()
go handleConnection(conn)
看到这里我曾经有个疑问,为什么不是 handleConnection(&conn) ? 会想这个问题的人肯定都知道如果conn是个struct,那就会发生复制,可能是写时复制,也可能是立即复制,这里面发生了什么不太清楚,反正感觉就是浪费了资源,但如果是指针传递,那就放心了,因为我们知道那肯定就是只复制了个指针而已,为了研究清楚这个问题,我做了下实现
如果一个函数的参数是接口类型,传进去的参数可以是指针,也可以不是指针,这得看你传的对象是怎么实现这个接口类型的
如果实现接口的方法的接收器是指针类型,则传参给接口类型时必需是指针,如果不是,则随便传
const width, height = 256, 256
img := ((0, 0, width, height))
(0, 0, &{})
(0, 0, {})
package main
import (
"fmt"
"reflect"
)
type ifa interface {
foo()
}
type test struct {
V int
}
// 如果接收器不是指针,则ifa接口可以是指针,也可以是对象,否则只能是指针
func (t test) foo() {
("fooooo:", )
}
func main() {
var aa ifa = &test{1234}
var ap = &aa
var o = (*ap).(*test)
var o2 = (*ap).(*test)
("main :", )
= 12
("main :", )
("main %p \n", &)
foo(ap)
("main end :", )
()
}
func foo(f *ifa) {
("f: type=%v, kind=%v \n", (f), (f).Kind())
if o, ok := (*f).(*test); ok {
("%p \n", &)
("foo before :", )
= 11
("foo after :", )
}
(*f).foo()
}
回到开始的问题,为什么不是 handleConnection(&conn) ?
1. 系统库本身就是传的指针,没必要
2. &conn取的是conn变量的地址,有被修改的可能,看下面代码
package main
import (
"fmt"
"reflect"
"time"
)
type ifa interface {
foo()
}
type test struct {
V int
}
// 如果接收器不是指针,则ifa接口可以是指针,也可以是对象,否则只能是指针
func (t test) foo() {
("fooooo:", )
}
func main() {
var o = test{1234}
var aa ifa = &o
("main1:", o)
go foo(&aa)
aa = &test{222}
<-(1 * )
("main2:", o)
}
func foo(f *ifa) {
<-(10 * )
("f: type=%v, kind=%v \n", (f), (f).Kind())
if o, ok := (*f).(*test); ok {
("%p \n", &)
("foo before :", )
= 11
("foo after :", )
}
(*f).foo()
}
能用指针就尽量用指针吧