删除重复的类型定义
Removing duplicate typedef's
我在以下程序中重复了代码。我需要将using VectorPtr = std::vector<T>*
移出两个foo
类。我需要将私有ptr
用作getVal
方法的返回指针。我该如何将别名移出课程?
enum ENUM
{
E1,
E2
};
template<ENUM e, class T> struct foo;
template<class T>
class foo<ENUM::E1, T>
{
public:
using VectorPtr = std::vector<T>*;
static VectorPtr getVal() { return ptr; }
private:
static VectorPtr ptr;
};
template<class T>
class foo<ENUM::E2, T>
{
public:
using VectorPtr = std::vector<T>*;
static VectorPtr getVal() { return ptr; }
private:
static VectorPtr ptr;
};
您需要模板using
template<class T>
using VectorPtr = std::vector<T>*;
template<ENUM e, class T> struct foo {
public:
static VectorPtr<T> getVal() { return ptr; }
private:
static VectorPtr<T> ptr;
};
或(使用相同的模板using
):
template<ENUM e, class T> struct foo;
template<class T>
class foo<ENUM::E1, T> {
public:
static VectorPtr<T> getVal() { return ptr; }
private:
static VectorPtr<T> ptr;
};
template<class T>
class foo<ENUM::E2, T> {
public:
static VectorPtr<T> getVal() { return ptr; }
private:
static VectorPtr<T> ptr;
};
相关文章:
- 有没有一种方法可以通过"typedef"为重新定义的基本类型定义特征和强制转换运算符
- 强枚举类型定义:Clang Bug 还是 C++11 标准不确定性?
- 列表参数的类型定义
- 使用模板化的键类型定义 std::map,该键类型基于作为参数接收的函数
- 关于 C++ 中的函数类型定义
- C++(和 ROS) - 包含与前向声明引用,设置默认值和类型定义
- 将使用/类型定义限制为类范围
- 模板类型定义?
- C++:模板类的类型定义
- 如何对命名空间限定类型进行类型定义?
- 此递归模板类型定义是否有效C++?
- 具有调整对齐方式的类型定义
- C++从抽象类型定义类成员
- 用于C++代码的 API 监视器类型定义 (XML)
- 如何将result_of与函数类型定义一起使用
- 在C++的适当类型定义位置
- 如何根据模板类型定义浮点常量?
- 如何为缺少预定义运算符而不扩展命名空间"std"的标准类型定义运算符>> (istream &, ...)?
- 参数化类的别名(或类型定义)内部类
- 如果我想从类型"T"定义元素的容器(来自 STL),那么"T"必须使用默认构造函数?