class A
{
public:
int m_a;
~A();
A(int a = 0);
A(const A& copyObj);
A(A&& moveObj);
};
A::~A()
{
cout << "end A." << endl;
}
A::A(int a):m_a(a)
{
cout << "start A.(init m_a):" << m_a << endl;
}
A::A(const A& copyObj)
{
m_a = copyObj.m_a;
cout << "start A.(copy)" << endl;
}
A::A(A&& moveObj)
{
m_a = moveObj.m_a;
cout << "start A.(move)" << endl;
}
void testVector()
{
vector<A> list;
A item;
item.m_a = 100;
list.emplace_back(item);
item.m_a = 200;
cout << list[0].m_a << endl;
list.emplace_back(A(2));
cout << list[1].m_a << endl;
list.emplace_back(3);
cout << list[2].m_a << endl;
}
int main()
{
testVector();
return 0;
}
用emplace_back的输出:
start A.(init m_a):0
start A.(copy)
100
start A.(init m_a):2
start A.(move)
start A.(copy)
end A.
end A.
2
start A.(init m_a):3
start A.(copy)
start A.(copy)
end A.
end A.
3
end A.
end A.
end A.
end A.
改用push_back的输出:
start A.(init m_a):0
start A.(copy)
100
start A.(init m_a):2
start A.(move)
start A.(copy)
end A.
end A.
2
start A.(init m_a):3
start A.(move)
start A.(copy)
start A.(copy)
end A.
end A.
end A.
3
end A.
end A.
end A.
end A.
结论:如果参数是构造函数的参数,emplace_back会少生成一个对象,少一次move。如果参数是一个对象,两个函数是一样的。