기본 유형을 기반으로 하는 유형의 Reflect.Kind 가져오기
PHP 프로그래밍에서는 기본 유형을 기반으로 유형을 반영하는 것이 중요한 기술입니다. Reflect.Kind는 PHP에서 제공하는 리플렉션 클래스 라이브러리의 속성으로, 변수의 데이터 유형을 결정하는 데 사용할 수 있습니다. Reflect.Kind를 사용하면 변수의 유형을 쉽게 얻고 해당 작업 및 처리를 수행할 수 있습니다. PHP 개발자의 경우 이 기술을 익히면 리플렉션 메커니즘을 더 잘 이해하고 사용하며 코드의 가독성과 유연성이 향상됩니다. 이 기사에서 PHP 편집자 Baicao는 기본 유형을 기반으로 Reflect.Kind를 얻는 방법을 자세히 소개하고 독자가 이 지식 포인트를 더 잘 익히는 데 도움이 되는 몇 가지 실용적인 예와 기술을 공유합니다.
질문 내용
인터페이스를 구현하지만 구현이 기본 유형을 기반으로 하는 유형에 대해 Reflect.kind를 Reflect.interface로 사용하고 싶습니다. type id string
이 질문에 대한 또 다른 대답은 kind()를 호출할 때 Reflect.interfaces를 반환하는 모든 유형의 Reflect.type을 얻는 방법일 수 있습니다.
바둑 놀이터의 전체 예는 다음과 같습니다.
type ID interface { myid() } type id string func (id) myid() {} func main() { id := ID(id("test")) fmt.Println(id) fmt.Println(reflect.TypeOf(id)) // How to get the kind to return "reflect.Interface" from the var "id"? fmt.Println(reflect.TypeOf(id).Kind()) }
Solution
reflect.typeof()
(和 reflect.valueof()
) 需要一个 接口{}
。基本上,无论您传递给 reflect.typeof()
的值是什么,如果它还不是接口值,它将隐式包装在 interface{}
中。如果传递的值已经是接口值,则其中存储的具体值将作为 interface{}
넘어가세요.
인터페이스에 대한 포인터가 의미가 있는 드문 경우 중 하나인 이러한 "재패킹"을 피하려면 실제로 여기서는 피할 수 없습니다. 인터페이스 값에 대한 포인터를 전달해야 합니다.
따라서 인터페이스에 포인터를 전달하면 포인터는 "point-to-type"의 유형 설명자를 얻기 위해 interface{}
值中。您可以使用 type.elem()
로 래핑됩니다. 즉, 포인터 유형의 유형 설명자가 될 포인터 유형의 요소 유형입니다. 당신이 찾고 있는 인터페이스 유형. p>
예:
으아악출력 내용(go 놀이터에서 사용해 보세요):
으아악관련 질문 보기: go에서 Reflect.valueof()와 value.elem()의 차이점은 무엇인가요?
위 내용은 기본 유형을 기반으로 하는 유형의 Reflect.Kind 가져오기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











예, H5 페이지 제작은 HTML, CSS 및 JavaScript와 같은 핵심 기술을 포함하는 프론트 엔드 개발을위한 중요한 구현 방법입니다. 개발자는 & lt; canvas & gt; 그래픽을 그리거나 상호 작용 동작을 제어하기 위해 JavaScript를 사용하는 태그.

CSS에서 크기 조정 기호를 사용자 정의하는 방법은 배경색으로 통합됩니다. 매일 개발에서, 우리는 종종 조정과 같은 사용자 인터페이스 세부 정보를 사용자 정의 해야하는 상황을 발생시킵니다.

인라인 블록 요소의 잘못 정렬 된 디스플레이에 대한 이유와 솔루션과 관련하여. 웹 페이지 레이아웃을 작성할 때, 우리는 종종 이상하게 겉보기에 이상한 디스플레이 문제가 발생합니다. 비교하다...

실시간 비트 코인 USD 가격 비트 코인 가격에 영향을 미치는 요인 향후 비트 코인 가격을 예측하기위한 지표 다음은 2018-2024 년 비트 코인 가격에 대한 몇 가지 주요 정보입니다.

브라우저의 인쇄 설정에서 페이지의 상단과 끝을 제어하기 위해 JavaScript 또는 CSS를 사용하는 방법. 브라우저의 인쇄 설정에는 디스플레이가 ...인지 제어 할 수있는 옵션이 있습니다.

세그먼터의 45도 곡선 효과를 달성하는 방법은 무엇입니까? 세분화 장치를 구현하는 과정에서 왼쪽 버튼을 클릭 할 때 오른쪽 테두리를 45도 곡선으로 바꾸는 방법과 포인트 ...

사용자 인터페이스 디자인에서 세그먼트 효과를 구현하기위한 팁, 세그먼터는 특히 모바일 애플리케이션 및 반응 형 웹 페이지에서 일반적인 탐색 요소입니다. ...

Flex 레이아웃 및 솔루션에서 텍스트를 과도하게 누락하여 컨테이너 개구부 문제가 사용됩니다 ...
