>백엔드 개발 >C++ >`std::array`는 일반 C 배열과 크기와 메모리 레이아웃이 동일합니까?

`std::array`는 일반 C 배열과 크기와 메모리 레이아웃이 동일합니까?

Barbara Streisand
Barbara Streisand원래의
2024-12-06 22:10:13174검색

Does `std::array` have the same size and memory layout as a regular C   array?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.