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

Can't use macro define class in C++

本文关键字:宏定义 C++ 不能      更新时间:2023-10-16

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

#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预印本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;
}

由于您使用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;

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

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);