C ++ set emplace()函數(shù)用于通過將新元素插入容器來擴展set容器。元素是直接構(gòu)建的(既不復(fù)制也不移動)。
通過給傳遞給該函數(shù)的參數(shù)args調(diào)用元素的構(gòu)造函數(shù)。
僅當(dāng)鍵不存在時才進行插入。
template <class.... Args> pair<iterator, bool> emplace (Args&&... args); //C++ 11 之后
args:傳遞來構(gòu)造要插入到集合中的元素的參數(shù)。
emplace()函數(shù)返回一個布爾對,它將指示是否發(fā)生了插入,并返回一個指向新插入元素的迭代器。
容器大小的對數(shù)。
沒有變化。
容器已修改。
盡管同時訪問出口元素是安全的,但在容器中進行迭代范圍并不安全。
如果引發(fā)異常,則容器中沒有任何更改。
讓我們看一下將元素插入到集合中的簡單示例:
#include <iostream> #include <set> using namespace std; int main(void) { set<char> m; m.emplace('a'); m.emplace('b'); m.emplace('c'); m.emplace('d'); m.emplace('e'); cout << "集合包含以下元素" << endl; for (auto it = m.begin(); it != m.end(); ++it) cout << *it<< ", "; return 0; }
輸出:
集合包含以下元素 a, b, c, d, e,
在上面的示例中,它只是將具有給定鍵值對的元素插入到集合m中。
讓我們看一個簡單的實例,插入元素并檢查重復(fù)鍵:
#include <set> #include <string> #include <iostream> using namespace std; template <typename S> void print(const S& s) { cout << s.size() << " 元素: "; for (const auto& p : s) { cout << "(" << p << ") "; } cout << endl; } int main() { set<string> s1; auto ret = s1.emplace("ten"); if (!ret.second){ cout << "Emplace失敗,值為“ten”的元素已經(jīng)存在。" << endl << " 現(xiàn)有元素是 (" << *ret.first << ")" << endl; cout << "set沒有被修改" << endl; } else{ cout << "集合已修改,現(xiàn)在包含 "; print(s1); } cout << endl; ret = s1.emplace("ten"); if (!ret.second){ cout << "Emplace失敗,值為“ten”的元素已經(jīng)存在。" << endl << " 現(xiàn)有元素是 (" << *ret.first << ")" << endl; } else{ cout << "集合已修改,現(xiàn)在包含 "; print(s1); } cout << endl; }
輸出:
集合已修改,現(xiàn)在包含 1 元素: (ten) Emplace失敗,值為“ten”的元素已經(jīng)存在。 現(xiàn)有元素是 (ten)
在上面的示例中,將元素插入到集合中,當(dāng)您嘗試使用相同的鍵“十”時,它將顯示一條錯誤消息,提示鍵“十”已經(jīng)存在。
讓我們看一個簡單的示例,查找插入元素的總和:
#include <iostream> #include <set> using namespace std; int main() { // sum變量聲明 int sum = 0; // set 聲明 set<int> myset{}; myset.emplace(1); myset.emplace(7); myset.emplace(4); myset.emplace(8); myset.emplace(2); myset.emplace(5); myset.emplace(3); // iterator 聲明 set<int>::iterator it; // 求元素之和 while (!myset.empty()) { it = myset.begin(); sum = sum + *it; myset.erase(it); } // 打印總和 cout << "元素的總和為: "<<sum; return 0; }
輸出:
元素的總和為: 30
讓我們看一個插入元素的簡單示例:
#include <iostream> #include <set> #include <string> using namespace std; int main() { typedef set<string> city; string name; city fmly ; int n; cout<<"輸入家庭成員的數(shù)量 :"; cin>>n; cout<<"輸入每個成員的姓名: \n"; for(int i =0; i<n; i++) { cin>> name; // Get key fmly.emplace(name); } cout<<"\n家庭的總成員是:"<< fmly.size(); cout<<"\n家庭成員列表: \n"; cout<<"\nName \n ________________________\n"; city::iterator p; for(p = fmly.begin(); p!=fmly.end(); p++) { cout<<(*p)<<" \n "; } return 0; }
輸出:
輸入家庭成員的數(shù)量: 3 輸入每個成員的姓名: Bob Robin David 家庭的總成員是: 3 家庭成員列表: Name ________________________ Bob David Robin
在上面的示例中,它只是根據(jù)用戶的選擇插入元素。