c++ - 如何在 C++ 中使用模板重构方法

标签 c++

我需要(或者更好的是,我有机会)重构一些代码以使其更清晰。

我想使用一些模板,因为我认为这是一个很好的选择,以减少代码重复。

这是我的hpp

class Monetary
{
 public:
  Monetary();
  Monetary(const rapidjson::Value& iMonetary);
  virtual ~Monetary();

  [...cut...]

 private:

  static void initMember(const rapidjson::Value& iMonetary, const char* iName, int& oMember);
  static void initMember(const rapidjson::Value& iMonetary, const char* iName, std::string& oMember);


 private:
  int _amount;
  int _decimal_place;
  std::string _currency;
  std::string _type;
};

下面是 initMember 方法的实现:

static void Monetary::initMember(const rapidjson::Value& iMonetary, const char* iName, int& oMember)
{
  rapidjson::Value::ConstMemberIterator aIterator;
  aIterator = iMonetary.FindMember(iName);
  if ( aIterator != iMonetary.MemberEnd() &&
      aIterator->value.IsNumber() )
  {
    oMember = iMonetary[iName].GetInt();
  }
}

static void Monetary::initMember(const rapidjson::Value& iMonetary, const char* iName, std::string& oMember)
{
  rapidjson::Value::ConstMemberIterator aIterator;
  aIterator = iMonetary.FindMember(iName);
  if ( aIterator != iMonetary.MemberEnd() &&
      aIterator->value.IsNumber() )
  {
    oMember = iMonetary[iName].GetString();
  }
}

我正在考虑写一些类似的东西

template<typename T>
void Monetary::initMember(const rapidjson::Value& iMonetary, const char* iName, T& oMember)
{
  rapidjson::Value::ConstMemberIterator aIterator;
  aIterator = iMonetary.FindMember(iName);
  if (aIterator == iMonetary.MemberEnd())
  {
    return;
    //throw monetaryException
  }
  assignFromValue(iMonetary[iName], oMember);
}
template<>
void Monetary::assignFromValue<int>(const rapidjson::Value& iValue, int& oMember)
{
  if (!iValue.IsNumber())
  {
    return;
    //throw monetaryException
  }
  oMember = iValue.GetInt();
}
template<>
void Monetary::assignFromValue<std::string>(const rapidjson::Value& iValue, std::string& oMember)
{
  if (!iValue.IsString())
  {
    return;
    //throw monetaryException
  }
  oMember = iValue.GetString();
}

有什么更聪明的方法可以做到这一点吗?

最佳答案

我的建议:

  1. 您不需要创建 assignFromValue 成员函数。如果您可以使用非成员函数实现功能,那么您应该更喜欢非成员函数。参见 How Non-Member Functions Improve EncapsulationHow Non-Member Functions Improve Encapsulation .

  2. 您不需要制作assignFromValue 函数模板。它们可以是简单的重载。


void assignFromValue(const rapidjson::Value& iValue,
                     int& oMember)
{
  if (!iValue.IsNumber())
  {
    return;
    //throw monetaryException
  }
  oMember = iValue.GetInt();
}

void assignFromValue(const rapidjson::Value& iValue,
                     std::string& oMember)
{
  if (!iValue.IsString())
  {
    return;
    //throw monetaryException
  }
  oMember = iValue.GetString();
}

关于c++ - 如何在 C++ 中使用模板重构方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43476184/

相关文章:

c++ - 不可变数据模型的内存管理

c++ - "set_unexpected"在VC2010中不起作用?

c++ - 用于获取 .so 文件中定义内容的 nm 实用程序返回错误

c++ - 为什么 std::string::append() 不如 std::string::operator+() 强大?

c++ - 使用 C++ 从线程启动应用程序

c++ - 如何从 ID3D11Texture2D 访问像素数据?

c++ - Doxygen 能否识别 std::shared_ptr 或 std::map

c++ - 'const' 在 operator() 重载中做了什么?

c++ - 为什么这个带有 WINAPI 的 c++ 语法是什么意思?

c++ - 将 MPI 等级分配给 gpu