C 가상 템플릿 방법: 템플릿 및 런타임 다형성 다루기
C에서 템플릿 전문화와 런타임 다형성을 결합하는 딜레마에 직면한 개발자들은 걸림돌을 만난다. 이러한 복잡성은 템플릿 매개변수를 허용하는 추상 클래스 내에서 가상 메서드를 구현하려고 시도할 때 발생합니다. 문제는 템플릿 함수를 인스턴스화하는 잠재적인 유형의 수가 너무 많아서 호출을 동적으로 디스패치하는 컴파일러의 기능을 방해하는 것에서 비롯됩니다.
이러한 제한을 극복하기 위해 다양한 접근 방식을 추구할 수 있습니다. 한 가지 옵션은 동적 다형성을 제거하고 파생되지 않은 유형을 사용하여 키-값 쌍을 저장하는 것입니다. 그런 다음 기본 클래스 템플릿을 사용하여 이러한 매핑을 해결할 수 있습니다.
<code class="cpp">class AbstractComputation { public: template <typename T> void setData(const std::string& id, T value) { m_store.setData(id, value); } template <typename T> T getData(const std::string& id) const { return m_store.getData<T>(id); } protected: ValueStore m_store; };</code>
또는 유형 삭제를 사용하여 템플릿 매개변수를 제거하면서 런타임 다형성을 유지할 수 있습니다. 예를 들어 Boost::any를 활용하면 유형 삭제 인수를 허용하는 구체적이고 템플릿이 아닌 함수를 생성할 수 있습니다.
<code class="cpp">class AbstractComputation { public: template <typename T> void setData(const std::string& id, T value) { setDataImpl(id, boost::any(value)); } template <typename T> T getData(const std::string& id) const { boost::any res = getDataImpl(id); return boost::any_cast<T>(res); } protected: virtual void setDataImpl(const std::string& id, const boost::any& value) = 0; virtual boost::any getDataImpl(const std::string& id) const = 0; };</code>
기본적으로 유형 삭제를 사용하면 Boost::any의 데이터를 저장할 수 있습니다. 유형이 안전한 데이터 검색을 활성화하면서 뒤에서는 모든 유형을 지원합니다.
위 내용은 다음은 귀하의 기사 내용에 맞는 몇 가지 질문 기반 제목입니다. * C 가상 템플릿 방법: 런타임 다형성으로 템플릿 전문화를 달성하는 방법은 무엇입니까? * C 템플릿 및 런타임의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!