hash_map::find
[!참고]
이 API는 사용되지 않습니다.대신 unordered_map Class.
요소에 지정 된 키에 해당 하는 키가 있는 hash_map의 위치를 가리키는 반복기를 반환 합니다.
iterator find(
const Key& _Key
);
const_iterator find(
const Key& _Key
) const;
매개 변수
- _Key
검색 중인 hash_map의 요소를 정렬 키에 일치 하는 키 값입니다.
반환 값
요소의 위치에 지정 된 키 또는 키에 일치 항목이 없을 경우 hash_map의 마지막 요소 다음에 나오는 위치와 주소를 지정 하는 반복기입니다.
설명
찾기 비교가 관계 이내를 기준으로 정렬 키가에 해당 하는 첫 순서는 이진 조건부 인수 키를 hash_map의 요소를 해결 하는 반복기를 반환 합니다.
경우 반환 값을 찾기 배정은 const_iterator, hash_map 개체를 수정할 수 없습니다.경우 반환 값을 찾기 배정은 반복기, hash_map 개체를 수정할 수 있습니다
Visual C++.NET 2003 멤버는 <hash_map> 및 <hash_set> 헤더 파일이 더 이상 std 네임 스페이스에 있지만 오히려 stdext 네임 스페이스로 이동 되었습니다.자세한 내용은 stdext 네임스페이스를 참조하십시오.
예제
// hash_map_find.cpp
// compile with: /EHsc
#include <hash_map>
#include <iostream>
int main( )
{
using namespace std;
using namespace stdext;
hash_map <int, int> hm1;
hash_map <int, int> :: const_iterator hm1_AcIter, hm1_RcIter;
typedef pair <int, int> Int_Pair;
hm1.insert ( Int_Pair ( 1, 10 ) );
hm1.insert ( Int_Pair ( 2, 20 ) );
hm1.insert ( Int_Pair ( 3, 30 ) );
hm1_RcIter = hm1.find( 2 );
cout << "The element of hash_map hm1 with a key of 2 is: "
<< hm1_RcIter -> second << "." << endl;
// If no match is found for the key, end( ) is returned
hm1_RcIter = hm1.find( 4 );
if ( hm1_RcIter == hm1.end( ) )
cout << "The hash_map hm1 doesn't have an element "
<< "with a key of 4." << endl;
else
cout << "The element of hash_map hm1 with a key of 4 is: "
<< hm1_RcIter -> second << "." << endl;
// The element at a specific location in the hash_map can be found
// using a dereferenced iterator addressing the location
hm1_AcIter = hm1.end( );
hm1_AcIter--;
hm1_RcIter = hm1.find( hm1_AcIter -> first );
cout << "The element of hm1 with a key matching "
<< "that of the last element is: "
<< hm1_RcIter -> second << "." << endl;
}
요구 사항
헤더: <hash_map>
네임 스페이스: stdext