C 영역에서 auto의 다재다능함은 종종 호기심을 불러일으키고 때로는 당황스럽기까지 합니다. 개인 유형과 함께 auto를 사용할 때 한 가지 당황스러운 관찰이 발생합니다.
놀랍게도 오류 없이 컴파일되는 다음 코드 조각을 고려하십시오.
class Foo { struct Bar { int i; }; public: Bar Baz() { return Bar(); } }; int main() { Foo f; auto b = f.Baz(); // ok std::cout << b.i; }
이 색다른 동작은 다음과 같은 질문을 촉발합니다. 왜 우리는 개인형은 자동으로 접근이 금지인데, 직접 접근은 금지되어 있는 걸까요?
이 수수께끼를 풀려면 메커니즘을 파헤쳐야 합니다. 자동차의. 유형 추론 규칙은 C 템플릿의 유형 추론 규칙을 대부분 반영합니다. 이러한 관찰은 앞서 언급한 코드 샘플에도 적용됩니다. 비공개 유형의 객체를 템플릿 함수에 대한 인수로 전달할 수 있는 것처럼:
template <typename T> void fun(T t) {} int main() { Foo f; fun(f.Baz()); // ok }
auto를 사용하여 해당 유형을 추론할 수도 있습니다. 이는 유형 이름 자체에 접근할 수 없더라도 유형 정보는 계속 사용할 수 있기 때문입니다. 이를 통해 개인 유형을 클라이언트 코드로 반환할 수 있으며 자동을 통한 금지된 액세스도 허용됩니다.
위 내용은 직접 액세스가 금지되어 있는데 '자동'으로 프라이빗 C 유형에 액세스할 수 있는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!