> 백엔드 개발 > C++ > C 11 삭제된 기능이 여전히 과부하 해결에 참여하는 이유는 무엇입니까?

C 11 삭제된 기능이 여전히 과부하 해결에 참여하는 이유는 무엇입니까?

Barbara Streisand
풀어 주다: 2024-12-19 12:40:09
원래의
459명이 탐색했습니다.

Why Do C  11 Deleted Functions Still Participate in Overload Resolution?

C 11에서 삭제된 함수가 오버로드 해결에 참여하는 이유

C 11에서는 특정 함수 오버로드의 호출을 방지하기 위해 = delete 구문을 도입했습니다. 특정 매개변수 유형. 오버로드 해결 중에 삭제된 함수가 고려 대상에서 완전히 제거될 것으로 예상할 수 있으므로 이 동작은 이상해 보일 수 있습니다. 그러나 이러한 설계 결정에는 구체적인 이유가 있습니다.

암시적 변환 방지

=delete의 주요 목적 중 하나는 특정 시나리오에서 암시적 변환의 사용을 금지하는 것입니다. 삭제된 오버로드가 있는 함수가 오버로드 해결에 참여하면 컴파일러가 정확히 일치하는 항목을 선택하거나 오류를 보고합니다. 이렇게 하면 암시적 변환을 사용하여 삭제된 오버로드를 실수로 호출하는 것을 방지할 수 있습니다.

아래 예를 고려하세요.

struct onlydouble {
  onlydouble(std::intmax_t) = delete; // Prevent implicit conversion from integer
  onlydouble(double);
};
로그인 후 복사

삭제된 오버로드가 고려 대상에서 완전히 제거된 경우 다음 코드가 허용됩니다. :

onlydouble val(20);
로그인 후 복사

컴파일러는 암시적으로 정수 리터럴을 double로 변환하고 삭제되지 않은 오버로드를 선택합니다. 그러나 삭제된 오버로드가 오버로드 해결에 참여하는 경우 컴파일러는 삭제된 오버로드를 정수 리터럴 인수와 정확히 일치하는 것으로 식별하기 때문에 코드를 거부합니다.

특수 구문 및 "This Does Not Exist"

C 11에서 = delete를 "이것은 존재하지 않습니다."가 아닌 "나는 이것을 금지합니다"로 정의하는 이유가 궁금할 수 있습니다. 대답은 존재하지 않음을 표현하기 위해 명시적인 문법이 필요하지 않다는 데 있습니다. 정의되지 않은 식별자와 누락된 특수 멤버 함수는 "이것은 존재하지 않습니다."라는 개념을 암시적으로 전달합니다.

결론

C 11에서 삭제된 함수는 암시적인 방지를 위해 오버로드 해결에 참여합니다. 변환하고 특정 매개변수 유형의 사용을 강제합니다. 이 설계 기능을 사용하면 함수 오버로드 호출을 정밀하게 제어할 수 있으므로 암시적 변환이 바람직하지 않거나 모호함으로 이어지는 시나리오에서 이점을 얻을 수 있습니다.

위 내용은 C 11 삭제된 기능이 여전히 과부하 해결에 참여하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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