【发布时间】:2019-09-25 04:49:44
【问题描述】:
有没有办法将构造函数分配给像'f'这样的函数:
struct C
{
C(int){};
};
auto f = C::C(int); // not work
auto g = [](int){ return C(int()); }; // works
C、C::C、&C、&C::C、C::&C、C::C(int)、&C::C(int) ... 都不起作用
Friday Pie 提出的解决方案:
template <class T>
struct ConstructHelper
{
template <class... Args>
static T&& construct(Args&&... args)
{
return std::move(T(std::forward<Args>(args)...));
}
};
auto f = ConstructHelper<C>::construct<int>; // works
auto c = apply(f, 0); // works
【问题讨论】:
-
你试图做的事情没有意义。
-
@Eugene 类似于
apply(func, args...),我们应该在 c++ 中有apply(cls, args...) -
你要
allocator_traits<C, Args...>::construct吗?但是接下来:谁提供构造C的内存位置?这就是它没有意义的原因。 -
构造函数没有类型也没有地址,并且不能在函数调用表达式中显式调用。它不会返回任何东西,甚至不会返回
void。
标签: c++