2

C++ 中的 const 字段必须在初始化列表中初始化,这使得从构造函数参数计算相互依赖的值变得非常重要。

例如,将这段 java 代码翻译成 c++ 的最佳方法是什么?

public class SomeObject {
  private final String some_string;
  private final int some_int;

  public SomeObject(final String input_filename){
    SomeReader reader(input_filename);

    some_string = reader.getString();
    some_int = reader.getInt();

    reader.close();
  }
}

我想过在 SomeObject 中封装一个子对象,但这只是转移问题;或使用静态方法构造对象:

class SomeObject {
  private:
    const std::string some_string;
    const int some_int;

  public:
    static SomeObject unserialize(const char * input_filename){
      SomeReader reader = new SomeReader(input_filename);

      string str = reader.get_string();
      int i = reader.get_int();

      reader.close();

      SomeObject obj(str, i);
      return obj;
    };

    SomeObject(const std::string str, const int i) :
      some_string(str),
      some_int(i)
    {};
}

有更好的解决方案吗?

谢谢你。

4

3 回答 3

3

这是 C++11 构造函数委托的一个很好的应用程序:

class SomeObject {
  private:
    const std::string some_string;
    const int some_int;

  public:
    // The "real" constructor for SomeObject
    SomeObject(std::string str, const int i) :
      some_string{std::move(str)},
      some_int{i}
    {}

    // Deserialize from SomeReader (delegates to the primary constructor)
    SomeObject(SomeReader& reader) :
      SomeObject{reader.get_string(), reader.get_int()} {}

    // Deserialize from SomeReader (accepts rvalues,
    //   delegates to the lvalue constructor)
    SomeObject(SomeReader&& reader) :
      SomeObject{reader} {}

    // Deserialize from named file (delegates to the SomeReader&& constructor)
    SomeObject(const char* input_filename) :
      SomeObject{SomeReader{input_filename}} {}
};
于 2014-09-10T18:08:12.930 回答
0

我认为你有正确的方法。

我会推荐几个小的改动。

这不是正确的 C++。

  SomeReader reader = new SomeReader(input_filename);

也许你的意思是:

  SomeReader reader(input_filename);

您可以更改行:

  SomeObject obj(str, i);
  return obj;

  return SomeObject(str, i);
于 2014-09-10T17:58:39.493 回答
0

您可以使用委托 ctorlambda-function,如下所示:

SomeObject(const char* filename) : SomeObject([&]{
    /* Do calculations here */
    return std::make_tuple(...);
}()) {}
SomeObject(std::tuple<...>&& x) : /* ... */ {}

尽管如此,一个更好的想法可能是重新设计以利用您在 C++ 中可以做而在 Java 中不能做的所有事情。

于 2014-09-10T18:06:30.733 回答