golang 튜토리얼의 다음 칼럼에서는 golang에서 메소드의 수신자가 포인터가 되는 것과 포인터가 아닌 것의 차이점에 대해 자세히 설명할 것입니다. 필요!
최근 한 학생이 저에게 golang의 메소드 수신자가 포인터인 것과 포인터가 아닌 것의 차이점이 무엇인지 물었습니다. 여기서는 간단하고 쉽게 설명하겠습니다. -이제 막 골랭을 배운 학생들에게 도움이 되는 방법을 이해하세요.
일부 학생들은 이미 이해한 것 같습니다. 포인터가 아닌 실제 매개변수가 전달되면 값이 복사됩니다. 그래서 TestValue()가 호출될 때마다 값이 복사됩니다.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) }
그럼 값을 수정하는 작업이 포함되면 결과는 어떻게 될까요?
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(https://github.com/qyuhen/book)에서 qyuhen의 독서 노트를 빌립니다. golang을 좋아하는 친구들에게 이 책을 추천해주세요. golang에 대한 이해를 심화하는 데 많은 도움이 됩니다.•
T 유형의 메소드 세트에는 모든 수신자 T +
• 유형 S에 익명 필드 T가 포함되어 있으면 S의 메서드 집합에는 T 메서드가 포함됩니다.• 유형 S에 익명 필드
T가 포함된 경우 S의 메서드 집합에는 T + T 메서드가 포함됩니다. • T 또는
T 임베딩에 관계없이
S 메서드 집합에는 항상 T + *T 메서드가 포함됩니다.
결론 golang은 간단하고 사용하기 쉽지만 여전히 많은 함정을 안고 있습니다. 저자는 golang을 사용하는 과정에서 많은 함정에 부딪혔는데, 이에 대해서는 나중에 블로그에서 언급하겠습니다.
위 내용은 golang의 메소드 수신자가 포인터인 것과 포인터가 아닌 것의 차이점은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!