Go 1.18에서 제네릭은 코드 유연성을 향상시키는 강력한 도구를 제공합니다. 그러나 유형 제약 조건을 사용할 때는 특정 오류가 발생할 수 있는 이유를 이해하는 것이 중요합니다.
다음 코드를 고려하세요.
컴파일을 시도할 때 이 코드를 사용하면 다음 오류가 발생할 수 있습니다.
이 오류는 일반 유형 제약 조건의 작동 방식에 대한 오해에서 비롯됩니다. blah 함수의 FooBar 제약 조건은 FooBar 인터페이스를 충족하는 유형에 대한 자리 표시자입니다. 그러나 변수 t는 유형 매개변수 T에 대한 포인터인 T 유형입니다. 이는 T가 유형 매개변수 자체가 아니므로 스트링거 인터페이스를 만족할 수 없음을 의미합니다.
이 문제에 대한 해결책은 유형 매개변수 T와 스트링거 인터페이스 간의 관계를 도입하는 것입니다. 두 가지 접근 방식이 있습니다:
1. 명시적 어설션
모든 유형 변환을 사용하여 *T가 스트링거 인터페이스를 충족함을 명시적으로 어설션할 수 있습니다.
2. 유형 구성
또는 FooBar와 스트링거의 제약 조건을 결합하는 새로운 유형을 정의할 수 있습니다.
이 접근 방식은 스트링거를 FooBar 인터페이스에 내장하고 제약 조건을 충족하려면 T가 포인터 유형이어야 합니다. FooBar.
Go에서 제네릭을 효과적으로 사용하려면 유형 제약 조건과 유형 매개변수 간의 관계를 이해하는 것이 중요합니다. 명시적 어설션이나 유형 구성을 통해 T와 스트링거 사이의 관계를 도입하면 오류를 해결하고 원하는 동작을 활성화할 수 있습니다.
위 내용은 My Go 일반 유형 매개변수가 `stringer` 인터페이스를 만족하지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!