2 回答
TA贡献1877条经验 获得超6个赞
当方法的接收器值是结构(而不是指向结构的指针)时,将复制完整的结构以按值传递给该方法。
因此,调用隐式读取字段(在创建结构的副本时),因此存在争用条件。v.Display()OtherValue
另一方面,使用指针时,仅复制指针,并且 并发访问 不会触发争用条件。v.displayv.OtherValue
TA贡献1815条经验 获得超6个赞
import (
"fmt"
"testing"
)
type TestStruct struct {
display bool
OtherValue int
}
func Display(t TestStruct) bool { // equal func (t TestStruct) Display() bool
return t.display
}
func DisplayP(t *TestStruct) bool { // equal func (t *TestStruct) DisplayP() bool
return t.display
}
func TestNonPointerRecevier(t *testing.T) {
v := &TestStruct{
display: true,
}
go func() {
v.OtherValue = 1 // write
}()
go func() {
fmt.Println(Display(*v)) // *v read value
}()
}
func TestPointerRecevier(t *testing.T) {
v := &TestStruct{
display: true,
}
go func() {
v.OtherValue = 1 // write
}()
go func() {
fmt.Println(DisplayP(v)) // un read, just pass parameter
}()
}
关注数据竞跑错误信息,调用方法时已经发生过,go会将v()转换为()。readDisplaytype *TestStructtype TestStruct
添加回答
举报
