inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

홍정모의 따라하며 배우는 C++

7.11 std vector를 스택처럼 사용하기

원소 하나를 push했는데 capacity가 2만큼 늘어났습니다.

433

joohyering

작성한 질문수 1

0

int main()
{
vector<int> v;

//push
v.push_back(1);

for (auto &e : v) cout << e << " ";
cout << endl;
cout << v.size() << " " << v.capacity() << endl;

v.push_back(2);

for (auto &e : v) cout << e << " ";
cout << endl;
cout << v.size() << " " << v.capacity() << endl;


v.push_back(3);

for (auto &e : v) cout << e << " ";
cout << endl;
cout << v.size() << " " << v.capacity() << endl;


//pop
v.pop_back();
for (auto &e : v) cout << e << " ";
cout << endl;
cout << v.size() << " " << v.capacity() << endl;

v.pop_back();
for (auto &e : v) cout << e << " ";
cout << endl;
cout << v.size() << " " << v.capacity() << endl;


return 0;
}

첨부한 코드와 같이 reserve를 하지 않고 size와 capacity의 변화를 보고자 프로그램을 짰습니다.

예상대로 push를 할 때는 size와 capacity가 함께 커졌고, pop을 할 때는 size는 작아졌으나 capacity는 그대로였습니다.

 그러나, 다음의 결과값을 보면 알 수 있듯이

결과값

/*

1 1

1 2 

2 2

1 2 3 

3 4

1 2 

2 4

1 4

*/

예외적으로 3을 push한 이후 갑자기 capacity가 2만큼 늘어났습니다.

왜 이런 일이 발생하게 되는 건가요?

(vector 초기화는 제vscode 버전이 uniform initialization을 지원하지 않아 저렇게 했습니다!)

C++

답변 2

8

안소

안녕하세요.

저는 비주얼 스튜디오를 통해 질문자님과 동일한 코드를 실행해보았는데 제가 돌린 경우에는 capacity가 2가 아닌 1만큼만 증가했습니다. (3 3 인 것을 확인할 수 있습니다)

다른 컴파일러를 사용해봤는데 여기서는 질문자님과 동일하게 2가 들어 3 4 가 출력된 것을 볼수 있네요.

벡터는 추가 작업으로 인해 capacity를 늘려야 할 때 얼만큼 늘릴지는 컴파일러마다 다르게 결정된다고 합니다. (참고) 보통 1.5배~2배 정도로 늘리는 것으로 결정되는 듯합니다.(출처블로그) 상황마다 얼마나 늘릴지는 컴파일러마다 다르게, 컴파일러만의 규칙에 따라 알아서 결정된다고 이해해주시면 될 것 같습니다.

0

joohyering

감사합니다!

변수가 메모리에 저장되는 것을 알려주는 강의가 어떤강의였죠

1

464

1

메모리 주소 10진수로 출력

1

653

1

클래스 템플릿 특수화에서 boolalpha로 표현된 리턴값에 대해 질문이 있습니다.

1

498

1

여러가지 리턴 타입에 관한 강의가 어떤 걸까요?

1

534

1

메모리 주소에 관한 질분

0

678

1

인터페이스 클래스에서 reportError의 매개변수에 대해 궁금한 것이 있습니다.

0

548

1

형변환 오버로딩에서 const 관련 질문이 있습니다.

0

443

1

Digit 뒤에 reference를 사용하는 이유

0

509

1

4.2 전역 변수, 정적 변수, 내부 연결, 외부 연결

0

322

1

dat파일이...

0

537

1

TODO:대입 연산자 오버로딩에 대한 소스코드입니다.

0

643

1

복사 생성자 관련 질문이 있습니다.

0

453

1

수업 중 궁금한점이 있습니다.

1

389

1

라이브러리자체가 이해가 되지 않습니다.

0

561

1

마지막 예제 질문

0

302

1

증감연산자 위치에 따른 수행 순서 질문입니다.

0

374

1

단항 연산자 오버로딩에서 return 부분에 질문이 있습니다.

1

410

1

friend함수 관련 질문이 있습니다.

0

311

1

operator+ 정의부분에서 궁금한 것이 있습니다.

0

447

1

3분 17초 질문

0

350

1

함수에 값을 대입한다는 개념이 이해가 되지 않습니다.

0

446

1

int getvalue() const에서 const는 왜 뒤에 붙는건가요?

0

442

2

const Something &st에서 const를 빼면 안되나요?

0

300

1

friend함수는 다른 클래스의 멤버함수로 쓸 수 없나요??

1

492

1