我有以下方法获取 C 风格结构的 vector 并一次处理它的一个元素。
我希望扩展它以接收更多类型的结构,而无需重复我的代码。
由于所有类型的结构都将包含相同的字段名称,因此使用模板来实现这一新要求将是最优雅的做法。
但是,我无法决定如何将第二个参数传递给 write_db
函数;该参数是每个结构类型的枚举 - 是否有任何选项可以在运行时获取它?
enum policy_types {
POLICY_TYPE_A,
POLICY_TYPE_B,
...
};
// old implementation - suitable for single struct only
int policyMgr::write_rule(std::vector <struct policy_type_a> & list) {
//conduct boring pre-write check
//...
for (auto & item : list ) {
int ret = write_db(item.key1, POLICY_TYPE_A_ENUM, &item.blob);
}
//new implementation - suitable for multiple structs.
template <POLICY>
int policyMgr::write_rule(std::vector <POLICY> & list) {
for (auto & item : list ) {
int ret = write_db(item.key1, type(POLICY) /* how can i get enum according to template type */, &item.blob);
}
我考虑过为结构的每个实例添加枚举值作为常量,但我希望找到一种不需要更改我的基本结构格式的更好方法。
最佳答案
如果不想添加成员,可以提供“traits”类型。
template<typename P>
struct PolicyTraits {};
template<>
struct PolicyTraits<policy_type_a>
{
static enum { Type = POLICY_TYPE_A };
};
template<>
struct PolicyTraits<policy_type_b>
{
static enum { Type = POLICY_TYPE_B };
};
template <typename A>
int policyMgr::write_rule(const std::vector<A> & list) {
for (const auto & item : list ) {
int ret = write_db(item.key1, PolicyTraits<A>::Type, &item.blob);
}
}
关于c++ - 在运行时获取模板类型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34606635/