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

단항 연산자는 람다 표현식을 인수로 사용하여 함수를 호출할 때 모호성을 어떻게 해결합니까?

Patricia Arquette
풀어 주다: 2024-11-14 16:22:02
원래의
327명이 탐색했습니다.

How does the unary   operator resolve ambiguity when calling a function with a lambda expression as an argument?

Lambda 함수에 대한 단항 연산자를 사용하여 모호한 오버로드 해결

제공된 코드 조각에서:

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

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

첫 번째 foo에 대한 호출이 모호하여 컴파일에 실패했습니다. 이러한 모호함은 람다 표현식이 암시적으로 std::function 및 void (*f)().

이 모호성을 해결하기 위해 두 번째 호출에서 람다 앞에 단항 연산자가 사용됩니다. 연산자는 람다 표현식을 두 번째 오버로드와 정확히 일치하는 함수 포인터 유형인 void(*)()로 변환합니다.

C 표준에 따르면:

  • 단항 연산자 인수를 기본 유형(산술, 열거형 또는 포인터)으로 변환합니다.
  • 람다 표현식의 경우 클로저 유형의 변환 함수는 매개변수와 반환 유형이 동일한 함수 포인터로 명시적으로 변환합니다.

따라서 []() {} 표현식은 두 번째 오버로드와 명확하게 일치하는 void (*)() 함수 포인터를 생성합니다.

람다 표현식이 다음을 수행할 수 있다는 점에 유의하는 것이 중요합니다. 또한 모호함을 피하기 위해 명시적으로 함수 포인터 유형으로 캐스팅해야 합니다.

foo((void (*)())([]() {}));
로그인 후 복사

위 내용은 단항 연산자는 람다 표현식을 인수로 사용하여 함수를 호출할 때 모호성을 어떻게 해결합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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