C ++ 라이브러리-<목록>
소개
List는 널리 사용되는 시퀀스 컨테이너입니다. 컨테이너는 동일한 유형의 데이터를 보유하는 개체입니다. 목록 컨테이너는 이중 연결 목록으로 구현되므로 데이터에 대한 양방향 순차 액세스를 제공합니다.
목록은 빠른 임의 액세스를 제공하지 않으며 양방향 순차 액세스 만 지원합니다. 목록은 일정한 시간에 시퀀스 내 어디서나 삽입 및 삭제 작업을 허용합니다.
목록의 요소는 다른 메모리 청크에 흩어져있을 수 있습니다. 컨테이너는 데이터에 대한 순차적 액세스를 허용하는 데 필요한 정보를 저장합니다. 목록은 런타임에 양쪽 끝에서 필요에 따라 축소하거나 확장 할 수 있습니다. 스토리지 요구 사항은 내부 할당 자에 의해 자동으로 충족됩니다.
크기가 0 인 목록도 유효합니다. 이 경우 list.begin () 및 list.end ()는 동일한 위치를 가리 킵니다. 그러나 front () 또는 back ()을 호출하는 동작은 정의되지 않았습니다.
정의
다음은 <list> 헤더 파일의 std :: list 정의입니다.
template < class T, class Alloc = allocator<T> > class list;
매개 변수
T − 포함 된 요소의 유형.
T는 사용자 정의 유형을 포함한 다른 데이터 유형으로 대체 될 수 있습니다.
Alloc − 할당 자 개체의 유형.
기본적으로 가장 간단한 메모리 할당 모델을 정의하고 값에 독립적 인 할당 자 클래스 템플릿이 사용됩니다.
회원 유형
다음 멤버 유형은 멤버 함수에 의해 매개 변수 또는 리턴 유형으로 사용될 수 있습니다.
Sr. 아니. | 회원 유형 | 정의 |
---|---|---|
1 | 값 _ 유형 | T (템플릿의 첫 번째 매개 변수) |
2 | 할당 자 _ 유형 | Alloc (템플릿의 두 번째 매개 변수) |
삼 | 참고 | 값 _ 유형 & |
4 | const_reference | const 값 _ 유형 & |
5 | 바늘 | 값 _ 유형 * |
6 | const_pointer | const 값 _ 유형 * |
7 | 반복자 | value_type에 대한 랜덤 액세스 반복기 |
8 | const_iterator | const value_type에 대한 임의 액세스 반복기 |
9 | reverse_iterator | std :: reverse_iterator <반복자> |
10 | const_reverse_iterator | std :: reverse_iterator <const_iterator> |
11 | 크기 유형 | size_t |
12 | 차이 _ 유형 | ptrdiff_t |
<목록>의 기능
아래는 <list> 헤더의 모든 메소드 목록입니다.
생성자
Sr. 아니. | 방법 및 설명 |
---|---|
1 | list :: list 기본 생성자 요소가없는 빈 목록을 구성합니다. |
2 | list :: list 채우기 생성자 n 개의 요소 로 새 목록을 구성하고 목록의 각 요소에 val 을 할당 합니다. |
삼 | list :: list 채우기 생성자 n 개의 요소 로 새 목록을 구성하고 목록의 각 요소에 0 값을 할당합니다. |
4 | list :: list 범위 생성자 처음 부터 마지막 까지의 범위에있는만큼 많은 요소로 목록을 구성 합니다. |
5 | list :: list 복사 생성자 기존 목록에있는 각 요소의 사본으로 목록을 구성합니다. |
6 | list :: list 이동 생성자 이동 시맨틱을 사용하여 other 의 내용으로 목록을 구성합니다 . |
7 | list :: list 이니셜 라이저 목록 생성자 이동 시맨틱을 사용하여 other 의 내용으로 목록을 구성합니다 . |
폐물 소각로
Sr. 아니. | 방법 및 설명 |
---|---|
1 | 목록 :: ~ 목록 목록 개체의 메모리 할당을 해제하여 파괴합니다. |
회원 기능
Sr. 아니. | 방법 및 설명 |
---|---|
1 | 목록 :: 범위 버전 할당 이전 값을 대체하여 목록에 새 값을 지정합니다. |
2 | 목록 :: 채우기 버전 지정 이전 값을 대체하여 목록에 새 값을 지정합니다. |
삼 | 목록 :: 초기화 목록 버전 할당 이전 값을 대체하여 목록에 새 값을 지정합니다. |
4 | list :: back 목록의 마지막 요소에 대한 참조를 반환합니다. |
5 | list :: begin 목록의 첫 번째 요소를 가리키는 임의 액세스 반복기를 반환합니다. |
6 | list :: cbegin 목록의 시작을 가리키는 상수 임의 액세스 반복기를 반환합니다. |
7 | list :: cend 목록의 끝을 가리키는 상수 임의 액세스 반복기를 반환합니다. |
8 | 목록 :: 지우기 목록에서 모든 요소를 제거하여 목록을 파괴하고 목록 크기를 0으로 설정합니다. |
9 | list :: crbegin 목록의 마지막 요소를 가리키는 상수 역방향 반복기를 반환합니다. |
10 | list :: crend 목록의 첫 번째 요소 앞에있는 이론적 요소를 가리키는 상수 역방향 반복기를 반환합니다. |
11 | list :: emplace 주어진 위치에 새 요소를 삽입하여 목록을 확장합니다. |
12 | list :: emplace_back 목록 끝에 새 요소를 삽입하고 목록 크기를 1 씩 늘립니다. |
13 | list :: emplace_front 목록 시작 부분에 새 요소를 삽입하고 목록 크기를 1 씩 늘립니다. |
14 | list :: empty 목록이 비어 있는지 여부를 테스트합니다. |
15 | list :: end 목록의 마지막 요소를 가리키는 임의 액세스 반복기를 반환합니다. |
16 | 목록 :: 지우기 위치 버전 목록에서 단일 요소를 제거합니다. |
17 | 목록 :: 지우기 범위 버전 목록에서 요소 범위를 제거합니다. |
18 | list :: front 목록의 첫 번째 요소에 대한 참조를 반환합니다. |
19 | list :: get_allocator 목록과 관련된 할당자를 반환합니다. |
20 | 목록 :: 단일 요소 버전 삽입 목록의 위치 에 새 요소를 삽입하여 반복자를 확장합니다 . |
21 | 목록 :: 채우기 버전 삽입 컨테이너에 새 요소를 삽입하여 목록을 확장합니다. |
22 | 목록 :: 범위 버전 삽입 컨테이너에 새 요소를 삽입하여 목록을 확장합니다. |
23 | 목록 :: 이동 버전 삽입 컨테이너에 새 요소를 삽입하여 목록을 확장합니다. |
24 | 목록 :: 초기화 목록 버전 삽입 컨테이너에 새 요소를 삽입하여 목록 확장 |
25 | list :: max_size 목록에서 보유 할 수있는 최대 요소 수를 반환합니다. |
26 | list :: merge 두 개의 정렬 된 목록을 하나로 병합합니다. |
27 | 목록 :: 병합 비교 기능 두 개의 정렬 된 목록을 하나로 병합합니다. |
28 | list :: merge 이동 버전 이동 의미 체계를 사용하여 정렬 된 두 목록을 하나로 병합합니다. |
29 | 목록 :: 병합 비교 기능 이동 버전 이동 의미 체계를 사용하여 정렬 된 두 목록을 하나로 병합합니다. |
30 | list :: operator = 복사 버전 이전 내용을 대체하여 목록에 새 내용을 할당합니다. |
31 | list :: operator = 버전 이동 이전 콘텐츠를 교체하여 목록에 새 콘텐츠를 할당합니다. |
32 | list :: operator = 이니셜 라이저 목록 버전 이전 콘텐츠를 교체하여 목록에 새 콘텐츠를 할당합니다. |
33 | list :: pop_back 목록에서 마지막 요소를 제거합니다. |
34 | list :: pop_front 목록에서 첫 번째 요소를 제거합니다. |
35 | list :: push_back 목록 끝에 새 요소를 삽입합니다. |
36 | list :: push_back 이동 버전 목록 끝에 새 요소를 삽입합니다. |
37 | list :: push_front 목록의 시작 부분에 새 요소를 삽입합니다. |
38 | list :: push_front 이동 버전 목록의 시작 부분에 새 요소를 삽입합니다. |
39 | list :: rbegin 목록의 마지막 요소를 가리키는 역방향 반복기를 반환합니다. |
40 | 목록 :: 제거 목록에서 값과 일치하는 요소를 제거합니다. |
41 | list :: remove_if 목록에서 조건을 충족하는 요소를 제거합니다. |
42 | list :: rend 목록의 반대 끝을 가리키는 역방향 반복기를 반환합니다. |
43 | list :: resize 목록의 크기를 변경합니다. |
44 | 목록 :: 값 버전 크기 조정 목록의 크기를 변경합니다. |
45 | list :: reverse 목록에있는 요소의 순서를 반대로합니다. |
46 | 목록 :: 크기 목록에있는 요소의 수를 반환합니다. |
47 | 목록 :: 정렬 목록의 요소를 정렬합니다. |
48 | 목록 :: 정렬 비교 기능 목록의 요소를 정렬합니다. |
49 | list :: splice 목록에서 * this로 모든 요소를 전송합니다. |
50 | 목록 :: 단일 요소 결합 반복자 i 가 가리키는 요소 를 목록 x 에서 * this로 전송 합니다. |
51 | 목록 :: 스플 라이스 이동 버전 이동 의미론을 사용하여 목록 x 에서 * this 로 모든 요소를 전송합니다 . |
52 | 목록 :: 접합 범위 버전 x 에서 * this 까지 처음 부터 마지막 까지 의 범위에있는 요소를 전송합니다 . |
53 | 목록 :: 스플 라이스 단일 요소 이동 버전 이동 의미론을 사용하여 반복기 i 가 가리키는 요소 를 목록 x 에서 * this 로 전송합니다 . |
54 | 목록 :: 접합 범위 및 이동 버전 이동 의미 체계를 사용하여 x 에서 * this 까지 처음 부터 마지막 까지 의 범위에있는 요소를 전송합니다 . |
55 | list :: swap 목록의 내용을 다른 목록 x의 내용과 교환합니다 . |
56 | list :: unique 목록에서 모든 연속 중복 요소를 제거합니다. |
57 | list :: unique 목록에서 모든 연속 중복 요소를 제거합니다. |
비 멤버 오버로드 함수
Sr. 아니. | 방법 및 설명 |
---|---|
1 | 연산자 == 두 목록이 같은지 여부를 테스트합니다. |
2 | 연산자! = 두 목록이 같은지 여부를 테스트합니다. |
삼 | 연산자 < 첫 번째 목록이 다른 목록보다 작은 지 여부를 테스트합니다. |
4 | 연산자 <= 첫 번째 목록이 다른 목록보다 작거나 같은지 여부를 테스트합니다. |
5 | 연산자> 첫 번째 목록이 다른 목록보다 큰지 여부를 테스트합니다. |
6 | 연산자> = 첫 번째 목록이 다른 목록보다 크거나 같은지 여부를 테스트합니다. |
7 | 교환 두 목록의 내용을 교환합니다. |