应该在成员函数中传递成员变量吗?

Should you pass member variables within member functions?

本文关键字:成员 变量 函数      更新时间:2023-10-16

这是一个风格问题。假设我有一个类A它必须对其成员变量B b执行一系列相当复杂的操作

class A {
 public:
  void DoStuffOnB(){
   DoThing1();
   DoThing2();
   DoThing3();
  }
 private:
  B b;
  void DoThing1(){ /* modify b */ }
  void DoThing2(){ /* modify b */ }
  void DoThing3(){ /* modify b */ }
};

,其中DoThings函数只依赖于b(或其他成员变量和一些传递的参数)。如果我想让这些函数将来在该类之外可重用,我最好将它们写成:

class A {
 public:
  void DoStuffOnB(){
   DoThing1(b);
   DoThing2(b);
   DoThing3(b);
  }
 private:
  B b;
  void DoThing1(B& b){ /* modify b */ }
  void DoThing2(B& b){ /* modify b */ }
  void DoThing3(B& b){ /* modify b */ }
};

,然后我的DoThing函数可以在未来的其他地方复制。我是应该把函数写成这样接受所有相关参数,还是应该只接受非成员参数?

如果答案是"你应该编写函数来接受所有相关参数",为什么要把它放在一个类中呢?

什么时候使用自由函数,什么时候使用成员函数?

从上下文中假设"在B上做点什么"函数操作B成员而不操作A中的其他状态,则:

  • 如果函数直接操作B的私有状态,那么它们应该是B的成员。

成员函数之所以是成员函数,是因为它的作用域不必使用引用和指针语法就可以访问成员变量。正如前面有人提到的那样,这很可能使代码和维护更简单,所以除非您需要函数是一个可能从不同类获取相同类型数据的自由函数,否则您将使用此方法,在这种情况下,您必须通过引用传递或使用指针来访问变量的作用域。

应该在成员函数中传递成员变量吗?

不需要将成员变量传递给成员函数,因为成员函数可以访问所有的数据成员。

它类似于访问静态文件局部变量的独立函数。函数可以访问同一转换单元中静态声明的变量。

何时应该使用独立函数,何时应该使用成员函数?

一般来说,当函数与对象相关联时,使用成员函数。

使用独立函数

  • 类有静态成员

  • 或功能与类相关联,不使用静态成员。

当相同的功能可以应用于不同的对象时,你也可以使用独立函数。
例如,让我们谈谈对象的序列化或输出。

可以在对象中定义方法load_from_buffer(),但它不能用于POD类型。

然而,如果一个函数load_from_buffer()是独立的,它可以重载不同的类型,如int, char, double和模板,重载可以调用从接口派生的对象。


当成员方法需要访问对象的数据成员时,首选使用成员方法。当静态成员方法访问静态数据成员或需要在没有对象实例的情况下使用该功能时(考虑封装),请使用静态成员方法。独立函数还提供了基于函数重载的不同对象的功能。

没有硬性的规则,只要使用你认为最容易维护的,有助于正确性和健壮性,加快开发。

只是为了迷惑人们,这里是Scott Meyers的一篇文章:
非成员函数如何提高封装性

请记住,为了使独立函数访问对象的数据成员,必须为数据成员提供公共访问权限,或者该函数需要是对象的友元。典型的例子是重载类的流操作符。