重写基于模板类型符号的虚拟方法
Overriding a virtual method based on template type sign
我正试图基于成员的签名性来覆盖一个虚拟方法,但不知怎么的,我做得不对。
我使用的是Visual Studio 2010,它不支持完整的C++11,但在gcc中也不编译。
#ifndef SIGNED_TEMPLATE_H_
#define SIGNED_TEMPLATE_H_
#include <type_traits>
#include <iostream>
class Base
{
public:
Base(void) {}
virtual ~Base(void) {}
virtual bool toValue(int *p) = 0;
void Signed(bool bSigned) { mSigned = bSigned; }
bool Signed(void) const { return mSigned; }
private:
bool mSigned;
};
template<typename T>
class ColumnDef : public Base
{
public:
ColumnDef(void) {}
template<typename T,
typename = std::enable_if<std::is_signed<T>::value>>
bool toValue(int *p) override
{
std::cout << "Signed" << std::endl;
return true;
}
template<typename T,
typename = std::enable_if<std::is_unsigned<T>::value>>
bool toValue(int *p) override
{
std::cout << "Unsigned" << std::endl;
return true;
}
};
#endif /* SIGNED_TEMPLATE_H_ */
您的覆盖是错误的
你必须转发你的电话,类似于:
template<typename T>
class ColumnDef : public Base
{
public:
ColumnDef() {}
bool toValue(int *p) override
{
return toValueImpl(p, std::is_unsigned<T>{});
}
private:
bool toValueImpl(int *p, std::true_type)
{
std::cout << "Signed" << std::endl;
return true;
}
bool toValueImpl(int *p, std::false_type)
{
std::cout << "Unsigned" << std::endl;
return true;
}
};
不能混合动态和静态多态性,虚拟函数不能是模板。
Jarod42的答案可能更简单,但只是为了演示在这种情况下如何使用enable_if:
class ColumnDef : public Base
{
public:
ColumnDef(void) {}
bool toValue(int *p)override
{
return toValueImpl<T>(p);
}
private:
template<typename T1>
typename std::enable_if<std::is_signed<T1>::value,bool>::type toValueImpl(int *p)
{
std::cout << "Signed" << std::endl;
return true;
}
template<typename T1>
typename std::enable_if<std::is_unsigned<T1>::value,bool>::type toValueImpl(int *p)
{
std::cout << "Unsigned" << std::endl;
return true;
}
};
相关文章:
- 在模板基类中为继承类中的可选重写生成虚拟方法
- 跨 DLL 边界访问虚拟方法是否安全/可能?
- 是否可以使用基类非虚拟方法中的派生类虚拟方法?
- 如何编写 operator= 用于使用虚拟方法与非平凡成员的匿名联合
- 让编译器告诉什么确切的纯虚拟方法使结构抽象?
- 使用模板而不是虚拟方法的管道模式
- 派生类调用父类的方法,该方法调用重写的虚拟方法调用错误的方法
- 为什么调用没有正文的纯虚拟方法不会导致链接器错误?
- 出于什么目的,非虚拟方法将与C++一起使用?
- 为什么使用存储在虚拟方法表中的地址调用虚拟函数的函数会返回垃圾?
- 如何重写继承的嵌套类中存在的虚拟方法
- 私有虚拟方法有什么用?
- 基类可以声明虚拟方法但不定义它吗?仍然在派生类中定义
- googletest:测试基类具有纯虚拟方法的派生类时的核心转储
- 确保模拟的 GTest 方法覆盖虚拟方法
- CPP 继承虚拟方法解析顺序
- 我是否应该在包含虚拟方法的类上使用'memcpy'?如果没有,如何替换它?
- 用c++中的纯虚拟方法抽象模板类
- 解决虚拟方法的歧义继承的两种方法
- 没有针对完全专用模板类的外联虚拟方法定义