> 백엔드 개발 > C++ > 본문

람다 표현식을 사용하여 함수 포인터 오버로딩의 모호성을 해결하는 방법은 무엇입니까?

Barbara Streisand
풀어 주다: 2024-11-20 00:20:03
원래의
471명이 탐색했습니다.

How to Resolve Ambiguity in Function Pointer Overloading with Lambda Expressions?

단항 플러스 연산자를 사용하여 람다 표현식으로 함수 포인터 오버로딩의 모호성 해결

함수 포인터와 std::function으로 함수를 오버로드하면 다음과 같은 경우 모호함이 발생할 수 있습니다. 람다 식을 인수로 전달하려고 합니다. 이러한 모호성은 람다 표현식이 함수 포인터와 std::function 모두로 암시적으로 변환될 수 있다는 사실에서 비롯됩니다.

이 모호성을 해결하려면 람다 표현식 앞에 단항 더하기 연산자( )를 사용할 수 있습니다. 연산자는 람다를 함수 포인터 유형으로 변환하도록 강제합니다. 이 경우 void ()()입니다. 이를 통해 오버로드 해결에서 foo(void (f)())의 함수 포인터 오버로드를 명확하게 선택할 수 있습니다.

다음 코드는 모호성을 해결하기 위해 연산자를 사용하는 방법을 보여줍니다.

#include <functional>

void foo(std::function<void()> f) { f(); }
void foo(void (*f)()) { f(); }

int main() {
    foo([]() {}); // ambiguous
    foo(+[]() {}); // not ambiguous (calls the function pointer overload)
}
로그인 후 복사

람다 표현식의 유형 변환 규칙과 단항 더하기 연산자의 효과를 이해함으로써 전달 시 함수 포인터 오버로딩의 모호성을 효과적으로 해결할 수 있습니다. 람다 표현식을 인수로 사용합니다.

위 내용은 람다 표현식을 사용하여 함수 포인터 오버로딩의 모호성을 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿