C 11의 함수 앨리어싱
C 11에서 using 지시문을 사용하는 클래스 앨리어싱은 간단합니다. 그러나 함수에 대한 별칭을 만드는 것은 더 어렵습니다.
문제:
다음 네임스페이스 및 함수 선언을 고려하세요.
<code class="cpp">namespace bar { void f(); }</code>
별칭 시도 g = bar::f;를 사용하는 함수 "f"는 "bar" 네임스페이스의 유형이 아니기 때문에 오류가 발생합니다.
Perfect Forwarding을 사용한 클린 솔루션:
함수 별칭을 생성하려면 , 완벽한 전달을 사용할 수 있습니다.
<code class="cpp">template<typename... Args> auto g(Args&&... args) -> decltype(f(std::forward<Args>(args)...)) { return f(std::forward<Args>(args)...); }</code>
이 솔루션을 사용하면 f가 오버로드되거나 함수 템플릿인 경우에도 g가 모든 인수를 f에 올바르게 전달하도록 보장합니다.
별칭 정의 :
별명 또는 B는 A의 모든 사용(선언 또는 정의 제외)에 대해 소스 코드에서 B를 대체하면 변경되지 않은 컴파일 결과가 발생하도록 보장하는 물질 A의 엔터티입니다. code.
예:
g 별칭을 정의한 후 다음 코드는 별칭을 통해 f를 호출합니다.
<code class="cpp">g(1, 2, 3); // Calls bar::f(1, 2, 3);</code>
위 내용은 C 11에서 함수 별칭을 만드는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!