C 표준의 std::array 크기
std::array에 대한 C 11 사양은 다음과 유사한 연속 스토리지 및 성능을 보장합니다. 일반 배열. 그러나 std::array가 표준 배열과 동일한 크기와 메모리 레이아웃을 가지고 있는지에 대한 의문이 제기됩니다.
표준 §23.3.2.1/2에 따르면 배열은 다음과 같은 집합체입니다. 다음 구문을 사용하여 초기화됩니다.
std::array<T, N> a = { initializer-list };
집계로서 std::array는 초기화 목록의 값을 직접 저장해야 합니다. 이론적으로 std::array가 보조 데이터를 저장하거나 일반 배열과 정렬이 다를 수 있지만 이러한 가능성은 거의 없습니다.
실제로 대부분의 컴파일러는 std::array를 연속된 블록으로 처리합니다. 일반 배열과 크기와 레이아웃이 동일한 메모리입니다. 이 동작은 타사 문서에서 지원되며 다양한 컴파일러에서 관찰됩니다.
예를 들어 std::array를 다차원 배열 포인터로 액세스하는 다음 코드는 예상대로 작동합니다.
std::vector<std::array<int, N>> x(M); typedef int (*ArrayPointer)[N]; ArrayPointer y = (ArrayPointer)&x[0][0]; // use y like normal multidimensional array
이러한 관찰을 바탕으로 일반적으로 다음과 같이 가정하는 것이 안전합니다.
sizeof(std::array<int, N>) == sizeof(int) * N
그러나 다음 사항에 유의하는 것이 중요합니다. 이 동작은 표준에 의해 엄격하게 보장되지 않습니다. 컴파일러는 std::array를 구현하는 방법에 있어 어느 정도 유연성을 갖고 있으며 향후 표준 개정판에서는 이 동작을 변경할 수 있습니다.
위 내용은 `std::array`는 일반 C 배열과 크기와 메모리 레이아웃이 동일합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!