포인터 유형에 대한 Go 메소드: 포인터 유형에 대해 수신기 T를 사용하여 메소드 호출 *T
질문:
Go 사양에서는 포인터 유형 T의 메소드 세트에 해당 유형 T의 메소드 세트가 포함되어 있다고 명시합니다. T 유형의 변수에 대해 리시버 T를 사용하여 메소드를 호출할 수 있습니까?
답변:
사양에서 이를 제안하고 있지만, T에서 *T의 메서드를 직접 호출할 수 없습니다. 대신 컴파일러는 자동으로 변수를 &T로 역참조하고 메서드를 호출하여 (&T).m()을 효과적으로 실행합니다.
이것은 동작은 Go 사양에 명시적으로 정의되어 있습니다.
"Calls: x의 메소드 세트(유형)에 m이 포함되어 있고 인수 목록이 매개변수 목록에 할당될 수 있는 경우 메소드 호출 x.m()이 유효합니다. x가 주소 지정 가능하고 &x의 메소드 세트에 m이 포함된 경우 x.m()은 (&x).m()의 약어입니다. "
데모:
다음 예에서는 이 동작을 보여줍니다.
package main import ( "fmt" "reflect" ) type User struct{} func (this *User) SayWat() { fmt.Println(reflect.TypeOf(this)) fmt.Println("WAT\n") } func main() { var user = User{} fmt.Println(reflect.TypeOf(user)) user.SayWat() }
*User 수신자를 사용하여 SayWat 메소드를 선언했음에도 불구하고 User 유형인 user에서 이를 호출할 수 있습니다. 컴파일러는 자동으로 역참조 및 호출을 처리합니다(&user).SayWat().
Exception:
그러나 이는 주소 지정 가능한 변수에만 적용됩니다. 주소를 지정할 수 없는 값에 대해 포인터 메서드를 호출하려고 하면 오류가 발생합니다. 예를 들어:
func aUser() User { return User{} } ... aUser().SayWat() // Error: cannot call pointer method on aUser()에서 포인터 메서드를 호출할 수 없습니다.
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3