我可以通过用C++03替换std::vector::push_back
并用C++ 11编译器编译来破坏一个有效的emplace_back
程序吗?通过阅读emplace_back
引用,我认为这是不应该发生的,但我承认我没有完全获得rvalue引用。
发布于 2014-02-27 23:45:37
我构造了一个简短的示例,当push_back
被emplace_back
替换时,它实际上无法编译。
#include <vector>
struct S {
S(double) {}
private:
explicit S(int) {}
};
int main() {
std::vector<S>().push_back(0); // OK
std::vector<S>().emplace_back(0); // error!
}
对push_back
的调用需要将其参数0
从int
类型转换为S
类型。因为这是一个隐式转换,所以不考虑显式构造函数S::S(int)
,并且调用S::S(double)
。另一方面,emplace_back
执行直接初始化,因此考虑了S::S(double)
和S::S(int)
。后者是一个更好的匹配,但它是private
,所以程序是错误的.
https://stackoverflow.com/questions/22080290
复制相似问题