C ++ STL 튜토리얼

앞서 논의한 C ++ 템플릿의 개념을 이미 이해 하셨기를 바랍니다. C ++ STL (표준 템플릿 라이브러리)은 벡터, 목록, 대기열 및 스택과 같은 인기 있고 일반적으로 사용되는 많은 알고리즘 및 데이터 구조를 구현하는 템플릿과 함께 범용 클래스 및 함수를 제공하는 강력한 C ++ 템플릿 클래스 집합입니다.

C ++ 표준 템플릿 라이브러리의 핵심에는 잘 구성된 세 가지 구성 요소가 있습니다.

Sr. 아니요 구성 요소 및 설명
1

Containers

컨테이너는 특정 종류의 개체 컬렉션을 관리하는 데 사용됩니다. deque, list, vector, map 등과 같은 여러 유형의 컨테이너가 있습니다.

2

Algorithms

알고리즘은 컨테이너에서 작동합니다. 컨테이너 내용의 초기화, 정렬, 검색 및 변환을 수행하는 수단을 제공합니다.

Iterators

반복기는 개체 컬렉션의 요소를 단계별로 실행하는 데 사용됩니다. 이러한 컬렉션은 컨테이너 또는 컨테이너의 하위 집합 일 수 있습니다.

다음 장에서는 C ++ 표준 라이브러리에 대해 설명하면서 세 가지 C ++ STL 구성 요소에 대해 모두 설명합니다. 지금은 세 가지 구성 요소 모두 복잡한 작업을 매우 쉽게 수행하는 데 도움이되는 미리 정의 된 풍부한 기능 집합을 가지고 있음을 명심하십시오.

배열과 유사한 벡터 컨테이너 (C ++ 표준 템플릿)를 보여주는 다음 프로그램을 살펴 보겠습니다. 단, 확장 될 경우 자체 스토리지 요구 사항을 자동으로 처리한다는 점이 다릅니다.

#include <iostream>
#include <vector>
using namespace std;
 
int main() {

   // create a vector to store int
   vector<int> vec; 
   int i;

   // display the original size of vec
   cout << "vector size = " << vec.size() << endl;

   // push 5 values into the vector
   for(i = 0; i < 5; i++) {
      vec.push_back(i);
   }

   // display extended size of vec
   cout << "extended vector size = " << vec.size() << endl;

   // access 5 values from the vector
   for(i = 0; i < 5; i++) {
      cout << "value of vec [" << i << "] = " << vec[i] << endl;
   }

   // use iterator to access the values
   vector<int>::iterator v = vec.begin();
   while( v != vec.end()) {
      cout << "value of v = " << *v << endl;
      v++;
   }

   return 0;
}

위의 코드가 컴파일되고 실행되면 다음과 같은 결과가 생성됩니다.

vector size = 0
extended vector size = 5
value of vec [0] = 0
value of vec [1] = 1
value of vec [2] = 2
value of vec [3] = 3
value of vec [4] = 4
value of v = 0
value of v = 1
value of v = 2
value of v = 3
value of v = 4

다음은 위의 예에서 사용한 다양한 기능과 관련하여 주목해야 할 사항입니다.

  • push_back () 멤버 함수는 벡터 끝에 값을 삽입하여 필요에 따라 크기를 확장합니다.

  • size () 함수는 벡터의 크기를 표시합니다.

  • 함수 begin ()은 벡터의 시작에 대한 반복자를 반환합니다.

  • end () 함수는 벡터의 끝까지 반복기를 반환합니다.