> 백엔드 개발 > C++ > 비구성 C 함수에서 암시적 변환을 방지하려면 어떻게 해야 합니까?

비구성 C 함수에서 암시적 변환을 방지하려면 어떻게 해야 합니까?

Barbara Streisand
풀어 주다: 2024-12-01 08:55:11
원래의
358명이 탐색했습니다.

How Can I Prevent Implicit Conversions in Non-Constructing C   Functions?

비구성 함수에서 암시적 변환 방지

문제 공식화:

C에서, 비구축 함수는 선언된 유형과 일치하도록 매개변수를 암시적으로 캐스팅할 수 있습니다. 이 동작은 어떤 경우에는 편리하지만 함수 매개변수를 특정 유형으로 제한하려고 할 때 예기치 않은 결과나 컴파일 오류가 발생할 수 있습니다.

해결책:

암시적 오류를 방지하려면 변환을 수행하고 비구성 함수가 특정 유형의 매개변수만 허용하는지 확인하려면 다음 기술을 사용할 수 있습니다. 취업:

1. 템플릿 삭제를 통한 함수 오버로딩(C 11 이상):

원하는 인수 유형과 일치하는 특정 템플릿 유형을 사용하여 함수 오버로드를 정의합니다. 그런 다음 다른 모든 유형에 대해 삭제되는 다른 함수 템플릿을 선언합니다. 이렇게 하면 해당 함수에 대한 암시적 변환이 효과적으로 비활성화됩니다.

void function(int);

// Delete overload for all other types
template<class T>
void function(T) = delete;
로그인 후 복사

2. 클래스 기반 함수 오버로드 삭제(C 11 이전):

암시적 변환을 방지하기 위한 이전 접근 방식에는 void 포인터를 사용하는 비공개 생성자로 클래스를 만드는 것이 포함되었습니다. 적절한 템플릿 인수를 사용하여 이 클래스를 인스턴스화하면 일치하지 않는 모든 오버로드가 삭제됩니다.

class DeleteOverload
{
private:
    DeleteOverload(void*);
};

template<class T>
void function(T a, DeleteOverload = 0);

void function(int a)
{}
로그인 후 복사

3. 정적 어설션(C 23 이상):

C 23에는 정적 어설션을 사용하여 함수가 올바른 유형으로 호출되었는지 확인하는 기능이 도입되었습니다. 이 접근 방식은 이전 방법에 비해 더 명확하고 유익한 오류 메시지를 제공합니다.

void function(int) {}

template<class T>
void function(T) {
    // Static assertion fails when called with non-matching types
    static_assert(false, "function shall be called for int only");
}
로그인 후 복사

이러한 기술 중 하나를 활용하면 비구성 함수가 특정 유형의 매개변수를 허용하도록 제한할 수 있으며 암시적 변환이 발생하지 않도록 합니다.

위 내용은 비구성 C 함수에서 암시적 변환을 방지하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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