emplace操作是C++11新特性,新引入的的三個成員emlace_front、empace 和 emplace_back,這些操作分別對應push_front、insert 和push_back,允許我們將元素放在容器頭部、一個指定的位置和容器尾部,而他們之間卻有一些不同,emplace*等操作根據(jù)參數(shù)執(zhí)行相應的構(gòu)造函數(shù),如果傳入的參數(shù)為容器元素類型則執(zhí)行拷貝構(gòu)造(這點和后三則相同),后三者在執(zhí)行時會調(diào)用拷貝構(gòu)造或則賦值運算符。
如下我們有一個類定義如下:
class emTest {public: emTest():data(0){ cout << "emTest()" << endl; } emTest(int data):data(data) { cout << "emTest(int)" << endl; } ~emTest() { cout << "~emTest()" << endl; } emTest(const emTest& that) { cout << "emTest(&)" << endl; data = that.data; } friend ostream& Operator<< (ostream& os, const emTest& that);PRivate: int data;};ostream& operator<< (ostream& os, const emTest& that) { os << that.data; return os;}通過類定義我們看到,有默認構(gòu)造函數(shù),接收一個整形參數(shù)的構(gòu)造函數(shù),還有一個拷貝構(gòu)造函數(shù),咱們可以使用emplace在vector首部放置元素,使用方法如下:
//調(diào)用默認構(gòu)造函數(shù)vec.emplace(vec.begin()); //調(diào)用接收int參數(shù)的構(gòu)造函數(shù)vec.emplace(vec.begin(), 4);//調(diào)用拷貝構(gòu)造函數(shù)emTest em;vec.emplace(vec.begin(), em);main函數(shù)內(nèi)的測試代碼如下:
int main(){ vector<emTest> vm; vm.reserve(4); emTest et(3); cout << "------------------------------------" << endl; vm.emplace(vm.begin(), et); vm.emplace(vm.begin() + 1); vm.emplace(vm.begin() + 2, 4); for(vector<emTest>::iterator i = vm.begin(); i < vm.end(); i++){ cout<< *i; } printf("/n"); cout << "------------------------------------" << endl;}測試輸出如下:
emTest(int)------------------------------------emTest(&) //vm.emplace(vm.begin(), et); 拷貝構(gòu)造emTest() //vm.emplace(vm.begin() + 1); 默認構(gòu)造emTest(int) //vm.emplace(vm.begin() + 2, 4); 接收一個int參數(shù)的構(gòu)造函數(shù)304 //vector內(nèi)的元素值------------------------------------~emTest() //程序退出時釋放vector內(nèi)存空間~emTest()~emTest()~emTest()我們對vector vm在使用push_front(vector沒有提供),insert,push_back,時不能通過傳入int來插入元素,于此同時在不同的平臺上還會有較大的可能構(gòu)造臨時對象,效率可能相對較低。
新聞熱點
疑難解答
圖片精選