emplace操作是C++11新特性,新引入的的三個成員emlace_front、empace 和 emplace_back,這些操作分別對應push_front、insert 和push_back,允許我們將元素放在容器頭部、一個指定的位置和容器尾部,而他們之間卻有一些不同,emplace*等操作根據參數執行相應的構造函數,如果傳入的參數為容器元素類型則執行拷貝構造(這點和后三則相同),后三者在執行時會調用拷貝構造或則賦值運算符。
如下我們有一個類定義如下:
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;}通過類定義我們看到,有默認構造函數,接收一個整形參數的構造函數,還有一個拷貝構造函數,咱們可以使用emplace在vector首部放置元素,使用方法如下:
//調用默認構造函數vec.emplace(vec.begin()); //調用接收int參數的構造函數vec.emplace(vec.begin(), 4);//調用拷貝構造函數emTest em;vec.emplace(vec.begin(), em);main函數內的測試代碼如下:
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); 拷貝構造emTest() //vm.emplace(vm.begin() + 1); 默認構造emTest(int) //vm.emplace(vm.begin() + 2, 4); 接收一個int參數的構造函數304 //vector內的元素值------------------------------------~emTest() //程序退出時釋放vector內存空間~emTest()~emTest()~emTest()我們對vector vm在使用push_front(vector沒有提供),insert,push_back,時不能通過傳入int來插入元素,于此同時在不同的平臺上還會有較大的可能構造臨時對象,效率可能相對較低。
新聞熱點
疑難解答
圖片精選