我想生成许多几乎没有什么区别的子类,所以我想使用宏来简化我的工作。宏定义如下:
#define DECLARE_SUB_CLASS(sub_class_name, base_class_name, value1) \
class sub_class_name:base_class_name \
{ \
public: \
virtual int initialize(const void *); \
virtual int run(const void *); \
virtual void reset(); \
virtual int output(const char*); \
virtual void terminate(); \
private: \
static const char m_szValue=#value1; \
};
我这样使用它:
DECLARE_SUB_CLASS(RTCount13, RTCountBase, 13);
当我用VC2005编译时,它说
error C2065: 'RTCount13' : undeclared identifier
有什么问题?
使用 gcc -E (或类似的其他预处理器)
gcc -E prepro.cxx
# 1 "prepro.cxx"
# 1 "<built-in>"
# 1 "<command-line>"
# 1 "prepro.cxx"
# 17 "prepro.cxx"
class RTCount13:RTCountBase {
public:
virtual int initialize(const void *);
virtual int run(const void *);
virtual void reset();
virtual int output(const char*);
virtual void terminate();
private:
static const char m_szValue="13";
};;
你尝试分配"13"
到一个字符。
顺便说一句,您还可以使用模板而不是宏来执行与宏完全相同的操作(即声明但不定义方法)。这是一个完整的(精简的)示例,其中包含单独的方法定义。
#include <iostream>
class RTCountBase {};
template <class base_class_name, int v>
class RTCount: base_class_name {
public:
virtual int output();
virtual void terminate();
private:
static const int m_szValue=v;
};
template <class base_class_name, int v>
int RTCount<base_class_name,v>::output(){ return m_szValue; }
template <class base_class_name, int v>
void RTCount<base_class_name,v>::terminate(){ std::cout <<" term "<<std::endl; }
typedef RTCount<RTCountBase,13> RTCount13; // typedef instead of macro
typedef RTCount<RTCountBase,14> RTCount14;
int main(){
RTCount13 myc13;
RTCount14 myc14;
std::cout << "my13: "<<myc13.output()<<std::endl;
std::cout << "my14: "<<myc14.output()<<std::endl;
return 0;
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)