不能在C ++中使用宏定义类

时间:2012-01-30 10:02:10

标签: c++ class macros c-preprocessor

我想生成许多只有差别很小的子类,所以我想用宏来简化我的工作。宏定义如下:

#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

问题是什么?

3 个答案:

答案 0 :(得分:8)

使用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"分配给char。

顺便说一句,您也可以使用模板而不是宏来执行宏所做的完全相同的事情(即声明但不定义方法)。这是一个完整的(修剪过的)示例,其中包含单独的方法定义。

#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;
}

答案 1 :(得分:2)

由于您使用的是C ++,因此您应该避免使用#define来执行此操作。 C ++语言有更好的方法,例如:

template <class B, const char C>
class SomeClass : public B
{
public:
  virtual int initialize(const void *) {return m_szValue;}
  virtual int run(const void *) {return 0;}
  virtual void reset() {}
  virtual int output(const char*) {return 0;}
  virtual void terminate() {}
private: 
  static const char m_szValue=C; 
};

然后改变这个:

DECLARE_SUB_CLASS(RTCount13, RTCountBase, 13);

RTCount13 some_instance;

为:

SomeClass <RTCountBase, 13> some_instance;

答案 2 :(得分:0)

定义静态字符时缺少哈希符号:

static const char m_szValue=#value1;

而不是

static const char m_szValue=##value1;

编辑:

如果m_szValue是string,则需要在类声明之外定义它。我建议你为此定义一个宏来保持一致性:

#define DECLARE_SUB_CLASS(sub_class_name, base_class_name) \
class sub_class_name:base_class_name \
{ \
    //.....\
private: \
    static const char* m_szValue; \
};

#define DEFINE_SUB_CLASS_STATIC(sub_class_name, value1) \
    const char* sub_class_name::m_szValue = #value1; \
你使用的

//header file
DECLARE_SUB_CLASS(RTCount13, RTCountBase);

//impl file:
DEFINE_SUB_CLASS_STATIC(RTCount13, 13);