C ++单函数变量放置

时间:2019-06-28 05:43:32

标签: c++ header conventions

我正在编写一个从文件读取数据的类。该项目仍在开发中,以后可能会更改文件名或路径,因此我将其存储在std :: string中,以便进行快速编辑。

鉴于文件名将在函数中使用多次,而仅在 one 函数中使用,关于我应该在哪里定义变量的规范cpp规则?

//don't know where I'll define this
std::string file_name = "path/to/file.foo";


//a.h file
class A {
public:
  void fileFunc();

private:
  //do i define it here?
};


//a.cpp file
A::fileFunc() {
  //or do i define it here?

  std::ifstream in(file_name);
  if(in) {
    //do things
  }
  else {
    std::cerr << "couldn't open " << file_name;
  }

}

1 个答案:

答案 0 :(得分:1)

使所有信息都贴近他们的使用。

这将有助于提高可读性和性能。参见:https://en.wikipedia.org/wiki/Locality_of_reference

所以

A::fileFunc() {
  const std::string file_name = "path/to/file.foo"; // pls use const when you can
  ...

A::fileFunc(const std::string& file_name) {
  ...

顺便说一句,我认为这应该在https://codereview.stackexchange.com/上,而不是stackoverflow。