C++에서 벡터(vector)와 배열의 차이는?
_____Q1: 벡터(vector)와 배열(array)의 기본적인 차이는 무엇인가요?
A1: 배열은 고정된 크기를 갖는 메모리 블록으로 선언 시 크기가 결정되고 변경할 수 없습니다. 반면, 벡터는 동적 크기를 지원하는 컨테이너로, 필요에 따라 자동으로 크기를 늘리거나 줄일 수 있습니다.
Q2: 배열과 벡터는 메모리 할당 방식이 어떻게 다른가요?
A2: 배열은 일반적으로 스택(stack) 또는 전역(static) 메모리에 할당됩니다(크기가 고정적일 경우). 벡터는 내부적으로 힙(heap) 메모리를 사용하여 동적으로 요소를 저장합니다.
Q3: 배열과 벡터 중 어느 쪽이 더 안전한가요?
A3: 벡터가 더 안전합니다. 벡터는 경계 검사(예: at() 함수)를 제공하며, 메모리 관리가 자동으로 이루어지므로 메모리 누수 위험이 줄어듭니다. 배열은 경계 검사가 없고, 크기를 직접 관리해야 하므로 실수가 발생하기 쉽습니다.
Q4: 벡터는 크기 조절이 가능한데, 배열은 왜 고정 크기로 설계되었나요?
A4: 배열은 단순성과 실행 속도를 중시하며, 컴파일 타임에 크기가 결정되어 메모리 접근이 빠릅니다. 벡터는 유연성을 위해 동적 크기 조절이 가능하도록 설계되었습니다.
Q5: 벡터를 사용할 때 성능은 배열과 비교해 어떤가요?
A5: 배열이 일반적으로 메모리 구조가 단순하고 캐시 친화적이어서 성능이 약간 우수할 수 있으나, 벡터는 동적 할당 및 재할당 과정에서 약간의 오버헤드가 발생할 수 있습니다. 하지만 실제 성능 차이는 사용 환경과 코드 최적화에 따라 달라집니다.
Q6: 벡터와 배열의 사용법 차이점은 무엇인가요?
A6:
- 배열은 고정 크기 선언 `int arr[10];`
- 벡터는 동적 크기 선언 `std::vector
Q7: 다차원 배열과 벡터 중 어느 것을 사용해야 하나요?
A7: 다차원 배열은 고정 크기와 빠른 메모리 접근이 필요할 때 적합하며, 벡터는 가변 크기와 동적 메모리 관리가 필요할 때 유용합니다. 벡터를 중첩하여 다차원 구조(`std::vector
Q8: 배열과 벡터 중 어느 쪽이 표준 라이브러리와 더 잘 통합되나요?
A8: 벡터는 C++ 표준 템플릿 라이브러리(STL)의 일부로서 다양한 알고리즘과 쉽게 통합되며, 반복자(iterator)를 통해 범용적으로 사용할 수 있습니다. 배열은 STL 알고리즘 입력으로도 사용 가능하지만, 특히 고정 크기 배열을 std::array로 대체하는 것이 추세입니다.
Q9: 배열 대신 std::array와 vector 중 무엇을 선택해야 하나요?
A9: `std::array`는 컴파일 타임에 크기가 결정되는 배열로 안전성과 STL 호환성을 개선한 버전입니다. 크기가 고정되어 있으면 `std::array` 사용을 추천하고, 크기가 가변적이면 `std::vector`가 적합합니다.
Q10: 벡터 메모리 재할당 시 주의할 점은?
A10: 벡터가 크기 제한을 넘어서면 내부적으로 더 큰 메모리를 할당하고 기존 데이터를 복사하거나 이동합니다. 이 과정에서 기존 요소의 참조자/포인터/이터레이터가 무효화될 수 있으므로, 재할당이 발생하는 상황을 고려해 코드를 작성해야 합니다. 배열은 크기가 고정되어 이런 문제가 없습니다.
---
요약:
- 배열 : 고정 크기, 스택 메모리, 빠르고 단순, 경계 검사 없음
- 벡터 : 동적 크기, 힙 메모리, 자동 메모리 관리, 경계 검사 가능, STL 호환 우수
벡터는 유연성과 안전성이 뛰어나 대부분의 상황에서 권장되며, 배열은 성능이 중요하거나 크기가 변하지 않는 경우 적합합니다.
작성자:
정지유 [비회원]
| 작성일자: 1년 전
2024-09-20 17:11:28
조회수: 218 | 댓글: 0 | 좋아요: 0 | 싫어요: 0
조회수: 218 | 댓글: 0 | 좋아요: 0 | 싫어요: 0
내용이 부정확하다면 싫어요를 클릭해주세요.