如何获取指向类的复制构造函数的成员函数指针?

时间:2016-10-27 16:22:33

标签: c++ c++11 c++14 copy-constructor member-function-pointers

有没有办法获得一个成员函数指针到类的复制构造函数?我知道如何定义和使用普通的成员函数指针,但我似乎无法找到一种方法来获取它。

1 个答案:

答案 0 :(得分:3)

根据C ++标准,“不应该使用构造函数的地址”,因此不可能按照您的要求进行操作。但是,有一个简单的解决方法。下面的代码返回一个函数指针,该函数指向一个创建它的输入副本的函数。

template<class obj> auto GetCopyConstructor() -> obj(*)(const obj&) 
{
    return +[](const obj& o) { return obj(o); };
}    
struct foo
{
    std::string msg;
    foo(const std::string& my_msg) { msg = my_msg; }
    foo(const foo&) = default;
};
int main()
{
    auto make_copy = GetCopyConstructor<foo>();
    foo a("Hello, world");
    foo b = make_copy(a);
    std::cout << b.msg << std::endl;
}

另外:(简化也包含其他用例)

template<class obj> obj Copy(const obj& o) { return obj(o); }
template<class obj> obj* CopyNew(const obj& o) { return new obj(o); }
template<class obj> obj CopyFromPtr(const obj* o) { return obj(*o); }
template<class obj> obj* CopyNewFromPtr(const obj* o) { return new obj(*o); }
template<class obj> void* WhyWouldYouEvenWantToDoThis(const void* o) 
{ return new obj(*(obj*)o); }
int main()
{
    foo(*make_copy)(const foo&) = Copy<foo>;
    foo a("Hello, world");
    foo b = make_copy(a);
    std::cout << b.msg << std::endl;
}