Union 제한 이해
C에서 Union은 여러 데이터 멤버가 공유하는 메모리 영역을 나타냅니다. 그러나 컴파일러는 공용체 내에서 중요하지 않은 생성자, 복사 생성자 또는 소멸자가 있는 클래스의 사용을 제한합니다.
문제
아래와 같이 문자열 멤버:
union U { int i; float f; string s; };
컴파일러는 U::s에 복사 생성자가 있음을 나타내는 오류를 발생시킵니다.
제한이 왜 필요한가요?
Union에서 사소한 작업이 포함된 클래스를 사용하면 메모리 관리 문제가 발생하기 때문에 이러한 제한이 존재합니다. 일반적인 구조체에서는 각 멤버에 자체 메모리가 할당됩니다. 그러나 공용체에서는 모든 멤버가 동일한 메모리 주소를 공유합니다.
아래 예를 고려하세요.
union U { string x; vector<int> y; }; U u; // <--
u가 구조체인 경우 u.x 및 u.y는 빈 문자열로 초기화됩니다. 및 벡터입니다. 그러나 유니온에서는 u.x와 u.y가 동일한 주소를 공유합니다. 따라서 둘 중 하나를 초기화하면 다른 하나의 데이터를 덮어쓰게 됩니다.
대안: 태그된 공용체 및 확장성
이 문제를 해결하기 위해 C 0x는 "태그된 공용체"를 도입했습니다. " 이러한 공용체를 사용하면 멤버 변수를 사용하여 활성 멤버를 나타낼 수 있으므로 공용체 내에서 클래스 멤버를 보다 유연하게 구성하고 삭제할 수 있습니다.
또는 Boost.Variant 및 Boost.Any와 같은 외부 라이브러리가 다음을 제공합니다. 메모리 관리의 복잡성을 캡슐화하면서 유사한 기능을 제공합니다.
위 내용은 C 공용체에서 중요한 생성자가 포함된 클래스를 사용할 수 없는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!