为变量模板的每个参数调用模板函数
Call template function for each argument of variardic template
我正在尝试使用专门的模板功能制作简单的DI,如下所示:
#include <iostream>
template<typename T>
T inject();
template<>
int inject() {
std::cout << "injected int" << std::endl;
return 123;
}
class Test {
public:
Test(int arg) {
std::cout << arg << std::endl;
}
};
template<typename C, typename... Args>
C* instantiate() {
return new C(inject<Args>()...);
}
int main() {
auto test = instantiate<Test>();
return 0;
}
显然,它不起作用。是否可以像这样推导出可变参数Args
并为每个变量调用instantiate
,将结果传递给给定的类型C
构造函数?
#include <type_traits>
#include <utility>
#include <cstddef>
struct injected {
operator int() const { return 123; }
operator double() const { return 3.14; }
operator const char*() const { return "foo"; }
};
template <std::size_t, typename T>
using repeat = T;
template <typename C>
C* instantiate(std::index_sequence<0, 1, 2, 3, 4, 5>) {
return nullptr;
}
template <typename C, std::size_t... Is>
auto instantiate(std::index_sequence<Is...>)
-> std::enable_if_t<std::is_constructible<C, repeat<Is, injected>...>{}, C*> {
return new C((void(Is), injected{})...);
}
template <typename C, std::size_t... Is>
auto instantiate(std::index_sequence<Is...>)
-> std::enable_if_t<not std::is_constructible<C, repeat<Is, injected>...>{}, C*> {
return instantiate<C>(std::index_sequence<Is..., sizeof...(Is)>{});
}
template <typename C>
C* instantiate() {
return instantiate<C>(std::index_sequence<>{});
}
演示
相关文章:
- 当对话框被接受时,如何用参数调用槽
- 使用用户定义的参数调用future/async并调用类方法
- 我使用向量来创建类对象列表.初始化向量时如何使用参数调用构造函数?
- 将成员函数作为构造函数参数调用时出错 "Variable is not a type name"
- 不允许运算符 const 参数调用 const 成员函数
- 为变量模板的每个参数调用模板函数
- 如何在窗口中使用注入的 dll 中的参数调用函数
- 按引用调用与按指针参数调用的差异 前递增和后递增
- 为什么使用不匹配的参数调用重载函数仍然有效
- PowerShell 使用结构类型参数调用 C++ DLL 的导出函数
- 基于枚举参数调用专用模板方法
- C++ 如何根据作为输入传递的参数调用一个构造函数或另一个构造函数?
- 如何使用类模板参数来更改参数调用和函数签名?
- lambda 函数使用其参数作为模板参数调用模板函数
- Android:使用 c++ 中的 byte[] 参数调用 java 方法
- 使用不同的模板参数调用模板类的对象
- C++编译时检查是否可以用某种类型的参数调用重载函数
- 是否可以基于类模板的参数调用类方法和全局方法
- 使用单独的参数调用"boost::process::system()"时,获取"execv
- C++大括号初始值设定项作为参数调用不同的构造函数,然后预期