C 코딩 영역에서 ' ' 연산자의 동작이 람다에 적용됩니다. (' []{}')는 호기심을 불러일으켰습니다. 코드가 틀에 얽매이지 않는 것처럼 보이지만 놀랍게도 주요 컴파일러를 사용하여 성공적으로 컴파일됩니다. 그런데 이 표준에 대한 예외는 어떻게 작동하나요?
이 동작을 이해하는 열쇠는 ' ' 연산자의 오버로드에 있습니다. 람다에 적용하면 ' '는 일반 기존 함수 포인터로의 변환을 트리거합니다. 이는 문제의 람다가 비캡처이므로 외부 변수를 참조하지 않기 때문에 가능합니다.
C 표준(섹션 5.1.2)에 따르면 비캡처 람다 클로저 객체는 다음과 같습니다. 함수 포인터를 반환하는 공개 비가상 변환 함수. 이 포인터는 람다와 동일한 동작을 하는 함수를 가리킵니다.
' ' 연산자에는 모든 유형을 포인터로 변환하는 내장 오버로드가 있습니다. . 람다의 경우 앞서 언급한 변환 함수가 오버로드 후보로 선택된다. 그 결과는 람다의 함수 호출 연산자와 동일한 매개변수 및 반환 유형의 함수 포인터입니다.
그래서 첫 번째 람다에 ''를 적용하면 람다 클로저 객체를 함수 포인터로 변환합니다. 이렇게 하면 두 람다 모두 호환 가능한 유형이 있으므로 두 번째 람다 클로저 객체를 동일한 함수 포인터에 할당할 수 있습니다.
예, ' []{}'를 사용하는 코드는 다음과 같습니다. 표준 준수. C 표준에서는 비캡처 람다 클로저 객체를 함수 포인터로 변환할 수 있습니다. 이 동작은 놀랍지만 유효한 코딩 트릭을 가능하게 합니다.
위 내용은 '' 연산자는 C에서 비캡처 람다와 어떻게 작동합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!