如何在c++中处理具有不同类型的多个数据成员的类

How to handle class with multiple data members of different type in c++?

本文关键字:同类型 数据成员 c++ 处理      更新时间:2023-10-16

假设我有一个类,它有许多不同类型的数据成员,并且可能在未来的中添加更多

Class A
{
public:
   int getA();
   void setA(int a);
   ...
private:
   int m_a;
   int m_b;
   double m_c;
   string m_d;
   CustomerType m_e;
   char * m_f;
   ...
}

问题是:每次添加另一个数据成员时,都需要添加get/set函数。出于某种原因,我不能把它们公开。

一种解决方案是将getType/setType函数与template:一起使用

Class A
{
public:
   int getInt(int id){
      switch(id)
        case ID_A:
            return m_a;
        case ID_B:
            return m_b;
        ...
   }
   void setInt(int id,int i){...}
   double getDouble(){...}
   void setDouble(int id,double d){...}
   ...
   template<T>
   T get();
   template<> //specialize
   double get<double>(){return getDouble();}
   ...
private:
}

有更好的解决方案吗?谢谢

这里有一个对我有用的策略。

#include <string>
struct CustomerType {};
class A
{
   public:
      template <typename T> struct member
      {
         typedef T type;
         type data;
      };
      struct type_A : member<int> {};
      struct type_B : member<int> {};
      struct type_C : member<double> {};
      struct type_D : member<std::string> {};
      struct type_E : member<CustomerType> {};
      struct type_F : member<char*> {};
      template <typename T>
         typename T::type get()
         {
            return ((T&)allData).data;
         }
      template <typename T>
         void set(typename T::type d)
         {
            ((T&)allData).data = d;
         }
   private:
      struct AllData : type_A,
                       type_B,
                       type_C,
                       type_D,
                       type_E,
                       type_F {};
      AllData allData;
};
int main()
{
   A a;
   a.set<A::type_A>(20);
   int b = a.get<A::type_A>();
   return 0;
}