2022年

2022年发布的文章
  • C++ protected(受保护的)详解

    在《C++类成员的访问范围》一节中介绍过类的成员可以是私有成员(private)和公有成员(public)。实际上,类的成员还可以用 protected 访问范围说明符修饰,从而成为“保护成员”。

    保护成员的可访问范围比私有成员大,比公有成员小。能访问私有成员的地方都能访问保护成员。

    保护成员扩大的访问范围表现在:基类的保护成员可以在派生类的成员函数中被访问。

    引入保护成员的理由是:基类的成员本来就是派生类的成员,因此对于那些出于隐藏的目的不宜设为公有,但又确实需要在派生类的成员函数中经常访问的基类成员,将它们设置为保护成员,既能起到隐藏的目的,又避免了派生类成员函数要访问它们时只能间接访问所带来的麻烦。

    不过需要注意的是,派生类的成员函数只能访问所作用的那个对象(即this指针指向的对象)的基类保护成员,不能访问其他基类对象的基类保护成员。来看下面的例子:

    class CBase {
        private: int nPrivate;   //私有成员
        public:  int nPublic;    //公有成员
        protected: int nProtected;   // 保护成员
    };
    class CDerived :public CBase
    {
        void AccessBase ()
        {
            nPublic = 1;      // OK
            nPrivate = 1;    // 错,不能访问基类私有成员
            nProtected = 1;  // OK,访问从基类继承的protected成员
            CBase f;
            f.nProtected = 1; //错,f不是函数所作用的对象
        }
    };
    int main()
    {
        CBase b;
        CDerived d;
        int n = b.nProtected ;  //错,不在派生类成员函数内,不能访问基类保护成员
        n = d.nPrivate;          //错,此处不能访问d的私有成员
        int m = d.nPublic;      //OK
        return 0;
    }

    第 11 行编译出错,因为在派生类的成员函数中不能访问基类的私有成员。

    第 12 行没有问题,在派生类的成员函数中可以访问基类的保护成员。

    第 14 行编译出错,因为 f 不是 this 指针所指向的对象,即不是 AccessBase 函数所作用的 对象,所以不能访问其保护成员。

    第 21 行和第 22 行都会编译出错,因为在类的成员函数外部,不能访问对象的私有成员和保护成员。

    在基类中,一般都将需要隐藏的成员说明为保护成员而非私有成员。

更多...

加载中...