本文說明如何在Visual C++ 中使用 set::find
標準範本庫 (STL) 函式。
原始產品版本: Visual C++
原始 KB 編號: 158576
必要的標頭
<set>
原型
template<class _K, class _Pr, class _A>
class set
{
public:
// Function 1:
const_iterator find(const _K& _Kv) const;
}
注意
原型中的類別/參數名稱可能不符合頭檔中的版本。 有些已修改以改善可讀性。
set::find 函式的描述
函 find
式是用來尋找受控制序列中的專案。 它會將反覆運算器傳回至受控制序列中的第一個專案,其排序索引鍵符合其參數。 如果不存在這類項目,傳回的反覆運算器會 end()
等於 。
範例指令碼
注意
在 Visual C++ .NET 和 Visual C++ 中, /EHsc 預設會設定,且相當於 /GX。
//////////////////////////////////////////////////////////////////////
// Compile options needed: -GX
// SetFind.cpp:
// Illustrates how to use the find function to get an iterator
// that points to the first element in the controlled sequence
// that has a particular sort key.
// Functions:
// find Returns an iterator that points to the first element
// in the controlled sequence that has the same sort key
// as the value passed to the find function. If no such
// element exists, the iterator equals end().
// Copyright (c) 1996 Microsoft Corporation. All rights reserved.
//////////////////////////////////////////////////////////////////////
#pragma warning(disable:4786)
#include <set>
#include <iostream>
#if _MSC_VER > 1020 // if VC++ version is > 4.2
using namespace std; // std c++ libs implemented in std
#endif
typedef set<int,less<int>,allocator<int> > SET_INT;
void truefalse(int x)
{
cout << (x?"True":"False") << endl;
}
void main()
{
SET_INT s1;
cout << "s1.insert(5)" << endl;
s1.insert(5);
cout << "s1.insert(8)" << endl;
s1.insert(8);
cout << "s1.insert(12)" << endl;
s1.insert(12);
SET_INT::iterator it;
cout << "it=find(8)" << endl;
it=s1.find(8);
cout << "it!=s1.end() returned ";
truefalse(it!=s1.end()); // True
cout << "it=find(6)" << endl;
it=s1.find(6);
cout << "it!=s1.end() returned ";
truefalse(it!=s1.end()); // False
}
程序輸出
s1.insert(5)
s1.insert(8)
s1.insert(12)
it=find(8)
it!=s1.end() returned True
it=find(6)
it!=s1.end() returned False