> 백엔드 개발 > C++ > 초기화 목록 또는 생성자 본문: C 필드 초기화에 가장 적합한 것은 무엇입니까?

초기화 목록 또는 생성자 본문: C 필드 초기화에 가장 적합한 것은 무엇입니까?

Susan Sarandon
풀어 주다: 2024-12-04 03:31:11
원래의
848명이 탐색했습니다.

Initializer List or Constructor Body: Which is Best for C   Field Initialization?

초기화자 목록과 생성자 본문: 필드 초기화 탐구

C를 사용한 객체 지향 프로그래밍 세계에서 일반적인 작업 중 하나는 다음과 같습니다. 클래스 필드 초기화 중. 초기화 목록과 생성자 본문은 이를 수행하는 두 가지 별개의 방법을 제공하지만, 둘 사이의 미묘한 차이점을 이해하는 것이 필수적입니다.

초기화 목록

초기화 목록 구문을 사용하면 본문이 실행되기 전에 생성자의 시작 부분에서 바로 멤버 변수를 초기화합니다. 이는 : 기호와 쉼표로 구분된 할당 목록을 사용하여 수행됩니다.

public: Thing(int _foo, int _bar): member1(_foo), member2(_bar) {}
로그인 후 복사

생성자 본문

생성자 본문에서 필드 초기화는 다음에서 발생합니다. 중괄호(매개변수 목록 뒤). 각 필드는 등호를 사용하여 명시적으로 할당됩니다.

public: Thing(int _foo, int _bar) {
    member1 = _foo;
    member2 = _bar;
}
로그인 후 복사
로그인 후 복사

비POD 유형의 차이점

비POD(Plain Old Data) 유형을 처리할 때, 이 두 가지 방법에는 결정적인 차이가 있습니다. 이러한 필드를 즉시 초기화하는 초기화 목록과 달리 생성자 본문은 본문 실행이 시작된 후에만 해당 필드를 초기화합니다.

이는 생성자 본문이 POD가 아닌 각 멤버에 대해 암시적으로 기본 생성자를 호출한다는 의미입니다. 이중 초기화가 발생합니다. 예를 들면 다음과 같습니다.

public: Thing(int _foo, int _bar) {
    member1 = _foo;
    member2 = _bar;
}
로그인 후 복사
로그인 후 복사

이는 다음과 실질적으로 동일합니다.

public: Thing(int _foo, int _bar) : member1(), member2() {
    member1 = _foo;
    member2 = _bar;
}
로그인 후 복사

안전에 미치는 영향

이 차이는 안전에 영향을 미칠 수 있습니다. POD가 아닌 멤버에 기본 생성자가 없는 경우 생성자 본문을 사용하면 컴파일 오류가 발생합니다. 대조적으로, 초기화 목록은 단순히 멤버 초기화를 건너뛰는데, 이는 상황에 따라 바람직할 수도 있고 원치 않을 수도 있습니다.

기본 매개변수

초기화 목록과 생성자 모두 본문은 기본 매개변수 값을 지원합니다. 그러나 동작은 동일하며 방법 선택은 기본 매개변수 처리 방법에 영향을 미치지 않습니다.

위 내용은 초기화 목록 또는 생성자 본문: C 필드 초기화에 가장 적합한 것은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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