머리말
최근 웹사이트의 한 학생이 저에게 golang의 메소드 수신자가 포인터인 것의 차이점이 무엇인지 물었습니다. 여기서는 방금 golang을 배운 학생들에게 도움이 되도록 간단하고 쉽게 설명하겠습니다. 실제로 이 원리를 이해한다면 방법은 무엇일까요? , 위에서 언급한 문제를 기본적으로 이해할 수 있습니다. 메소드는 실제로 특수 함수이고 수신자는 암시적으로 첫 번째 실제 매개변수가 전달됩니다.
예를 들어보세요type test struct{ name string } func (t test) TestValue() { } func (t *test) TestPointer() { } func main(){ t := test{} m := test.TestValue m(t) m1 := (*test).TestPointer m1(&t) }이제 이해하기 쉽나요? 포인터와 포인터가 아닌 것의 차이점을 확인하려면
type test struct{ name string } func (t test) TestValue() { fmt.Printf("%p\n", &t) } func (t *test) TestPointer() { fmt.Printf("%p\n", t) } func main(){ t := test{} //0xc42000e2c0 fmt.Printf("%p\n", &t) //0xc42000e2e0 m := test.TestValue m(t) //0xc42000e2c0 m1 := (*test).TestPointer m1(&t) }일부 학생들은 이미 이해했을 것입니다. 실제 매개변수가 포인터가 아닐 때 전달되면 TestValue()가 호출될 때마다 값이 복사됩니다.
값을 수정하면 결과는 어떻게 될까요?
type test struct{ name string } func (t test) TestValue() { fmt.Printf("%s\n",t.name) } func (t *test) TestPointer() { fmt.Printf("%s\n",t.name) } func main(){ t := test{"wang"} //这里发生了复制,不受后面修改的影响 m := t.TestValue t.name = "Li" m1 := (*test).TestPointer //Li m1(&t) //wang m() }
따라서 프로그래밍에서 이러한 문제가 발생하면 모든 학생들이 주의해야 합니다.
여기서 이러한 메서드 세트 간의 관계는 무엇입니까? golang을 공부하면서 qyuhen의 노트를 빌렸습니다. golang을 좋아하는 친구들에게도 이 책을 추천합니다. golang에 대한 이해를 심화하는 데 매우 도움이 됩니다.• Type T 메소드 세트에는 모든 수신기 T 메소드가 포함되어 있습니다.
•
T 메소드가 포함되어 있습니다.
• 유형 S에 익명 필드 T가 포함되어 있으면 S의 메서드 집합에는 T 메서드가 포함됩니다.
T가 포함된 경우 S의 메서드 집합에는 T +T 메서드가 포함됩니다.
• T 또는 T 임베딩에 관계없이 S 메서드 집합에는 항상 T + *T 메서드가 포함됩니다.
결론
golang은 간단하고 사용하기 쉽지만 여전히 많은 함정을 안고 있습니다. 저자는 golang을 사용하는 과정에서 많은 함정에 부딪혔는데, 이에 대해서는 나중에 블로그에서 언급하겠습니다.