卓越飞翔博客卓越飞翔博客

卓越飞翔 - 您值得收藏的技术分享站
技术文章77663本站已运行443

C++ 函数的黑暗面:类的成员函数的噩梦

c++++ 类的成员函数隐藏着一些陷阱,包括隐式 this 指针的意外修改、常量函数不能直接修改对象状态,以及嵌套函数访问控制的复杂性。这些陷阱可能导致破坏对象引用、编译错误和不可预期的行为。

C++ 函数的黑暗面:类的成员函数的噩梦

C++ 函数的黑暗面:类的成员函数的噩梦

在 C++ 开发中,类的成员函数看似简单,却暗藏着不少陷阱。本文将深入探讨这些陷阱,揭示成员函数潜在的危机。

隐式 this 指针

成员函数的一个关键特性是它们的隐式 this 指针,它指向当前函数所属的对象。这为方便访问类成员提供了便利,但也可能带来问题。

陷阱:如果在成员函数中修改了 this 指针,会破坏对当前对象的引用,导致混乱和未定义的行为。

立即学习“C++免费学习笔记(深入)”;

常量成员函数

const 成员函数不允许修改对象的任何非静态成员数据。这意味着它们无法直接修改成员变量,也无法调用非 const 成员函数。

陷阱:不小心将成员函数声明为 const,却试图修改对象内部状态,会导致编译错误或运行时异常。

嵌套成员函数

当一个成员函数内又存在另一个成员函数时,就形成了嵌套成员函数。这种嵌套带来了一系列复杂性:

陷阱:嵌套成员函数的访问控制比外部函数更加严格。嵌套函数无法访问外部函数的私有成员,而外部函数可以访问嵌套函数的私有成员。这可能导致无法访问预期的数据或不可预期的行为。

实例:类的成员函数噩梦

代码:

class MyClass {
public:
    int x;  // 成员变量

    void set_x(int val) {  // 修改 this->x 的成员函数
        this->x = val;
    }

    int get_x() const {  // 不修改 this->x 的常量成员函数
        return this->x;
    }

    void nested_func() {  // 嵌套成员函数
        cout << x << endl;  // 访问外部成员变量
    }
};

int main() {
    MyClass obj;
    obj.set_x(5);  // 陷阱 1:修改 this 指针后,无法正常访问对象
    obj.set_x(10);  // 陷阱 2:试图修改常量成员函数中的值
    obj.nested_func();  // 陷阱 3:嵌套成员函数访问外部私有成员
    return 0;
}

陷阱演示:

  1. 陷阱 1: set_x 函数修改了 this 指针,导致 obj 对象的 x 成员变量无法访问。
  2. 陷阱 2: get_x 函数声明为 const,但 set_x 试图修改其值,引发编译错误。
  3. 陷阱 3: nested_func 嵌套在 MyClass 中,可以访问其私有成员变量 x,而外部代码无法访问该私有成员。
卓越飞翔博客
上一篇: C++ 函数的黑暗面:单元测试最佳实践
下一篇: 返回列表
留言与评论(共有 0 条评论)
   
验证码:
隐藏边栏