Go의 함수 내 중첩 클래스: 가능성과 한계
Go에서는 함수 내 중첩 구조체가 허용되지만 중첩 클래스를 생성하는 기능 함수(람다 함수 이외의)는 제한됩니다. 이는 다음과 같은 질문을 제기합니다. 함수 내에서 중첩 클래스를 정의하는 것이 실제로 불가능합니까?
설명하기 위해 다음 코드 조각을 고려하십시오.
<code class="go">func f() { // Nested struct Cls within f type Cls struct { //... } // Attempt to bind foo to Cls (fails) func (c *Cls) foo() { //... } }</code>
이 예에서 중첩된 구조체 Cls의 멤버로 foo 함수를 정의하면 실패합니다. 중첩된 구조체가 제공하는 유연성을 고려할 때 이러한 제한은 이상해 보일 수 있습니다.
그러나 Go의 중첩 함수는 함수에 수신자가 있는지 여부에 관계없이 본질적으로 허용되지 않는다는 점을 인식하는 것이 중요합니다.
이러한 제한을 피하기 위해 Go는 아래와 같이 다른 함수 내에서 함수 선언을 허용하는 함수 리터럴을 제공합니다.
<code class="go">func f() { foo := func(s string) { fmt.Println(s) } foo("Hello World!") }</code>
이 예에서는 외부 함수 f 내에서 함수 변수 foo를 만듭니다. . 이 변수는 "Hello World!" 인수로 호출할 수 있는 함수를 저장합니다. 외부 함수 f가 호출되면 "Hello World!" 예상대로 인쇄됩니다.
함수 리터럴을 활용하는 이 접근 방식을 사용하면 특정 제약 조건 내에서도 함수 내 중첩 클래스를 에뮬레이션할 수 있습니다.
위 내용은 Go의 함수 내에 중첩 클래스가 존재할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!