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

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

Patricia Arquette
Patricia Arquette원래의
2024-11-14 16:22:02416검색

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 표준에 따르면:

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

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

람다 표현식을 함수 포인터 유형으로 명시적으로 캐스팅하여 이를 방지할 수도 있다는 점에 유의하는 것이 중요합니다. 모호함:

foo((void (*)())([]() {}));

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

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.