Private and Protected Members : C++
有人能告诉我在课堂上
我从最佳实践惯例中了解到,不在类外调用的变量和函数应该被设置为
有什么区别,我应该用哪种?
私有成员只能在定义它们的类中访问。
在定义受保护成员的类和从该类继承的类中,可以访问受保护成员。
编辑:这两个类的朋友也可以访问,如果是受保护的成员,也可以通过其派生类的朋友访问。
编辑2:在问题的上下文中使用任何有意义的东西。您应该尽可能使成员成为私有的,以减少耦合并保护基类的实现,但是如果这不可能,那么使用受保护的成员。检查C++常见问题,以便更好地理解这个问题。关于受保护变量的这个问题也可能有帮助。
所有人和所有人都可以访问A级的公共成员。
类A的受保护成员在代码之外是不可访问的,但可以从派生自A的任何类的代码访问。
类A的私有成员不能在代码之外访问,也不能从派生自A的任何类的代码访问。
因此,最终,在受保护或私有之间进行选择是为了回答以下问题:您愿意为派生类的程序员提供多少信任?
默认情况下,假定派生类不受信任,并将成员设为私有。如果您有一个非常好的理由让母类的内部构件自由访问其派生类,那么您可以使它们受到保护。
可以从派生类访问受保护的成员。私人的不行。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 | class Base { private: int MyPrivateInt; protected: int MyProtectedInt; public: int MyPublicInt; }; class Derived : Base { public: int foo1() { return MyPrivateInt;} // Won't compile! int foo2() { return MyProtectedInt;} // OK int foo3() { return MyPublicInt;} // OK };?? class Unrelated { private: Base B; public: int foo1() { return B.MyPrivateInt;} // Won't compile! int foo2() { return B.MyProtectedInt;} // Won't compile int foo3() { return B.MyPublicInt;} // OK }; |
就"最佳实践"而言,这取决于。如果甚至有一种微弱的可能性,某人可能希望从您现有的类派生一个新的类,并且需要访问内部成员,那么就让它们受到保护,而不是私有的。如果它们是私有的,您的类可能很难轻易继承。
MFC支持受保护的原因是它是一个框架。您可能希望子类化MFC类,在这种情况下,需要一个受保护的接口来访问类的一般使用不可见的方法。
这完全取决于您想要做什么,以及您希望派生类能够看到什么。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 | class A { private: int _privInt = 0; int privFunc(){return 0;} virtual int privVirtFunc(){return 0;} protected: int _protInt = 0; int protFunc(){return 0;} public: int _publInt = 0; int publFunc() { return privVirtFunc(); } }; class B : public A { private: virtual int privVirtFunc(){return 1;} public: void func() { _privInt = 1; // wont work _protInt = 1; // will work _publInt = 1; // will work privFunc(); // wont work privVirtFunc(); // wont work protFunc(); // will work publFunc(); // will return 1 since it's overridden in this class } } |
标记为
除非您不想使用或提供重写可能子类中的方法的可能性,否则我将使它们成为
受保护的成员只能由类的后代和同一模块中的代码访问。私有成员只能由声明它们的类和同一模块中的代码访问。
当然,朋友的功能会把这个扔到窗外,但哦,好吧。
私有成员只能从类中访问,受保护的成员可以在类和派生类中访问。它是OO语言中继承的一个特性。
您可以在C++中拥有私有的、受保护的和公共的继承,这将决定继承类中的派生类可以访问什么。例如,只有公共继承权。
请看一下"受保护成员变量"问题。建议使用私有作为默认值(就像C++ EDCOX1,2个SES DO)来减少耦合。受保护的成员变量通常是一个坏主意,受保护的成员函数可以用于模板方法模式。
private=仅由母舰(基类)访问(只有我父母才能进我父母的卧室)
受保护=母舰(基类)和她的女儿可以访问(即只有我的父母才能进入我父母的卧室,但允许儿子/女儿进入父母的卧室)
公共=母舰(基本类)、女儿和其他人可以访问(只有我的父母才能进我父母的卧室,但这是一个家庭聚会-米卡萨苏卡萨)
由于不需要公共成员函数来获取和更新派生类中受保护的成员,因此这会提高代码的效率并减少我们需要编写的代码量。然而,派生类的程序员应该知道他在做什么。
私有成员只能在声明为"受保护成员"的同一类中访问,在声明为"受保护成员"的类中可以访问该成员及其继承的类。
private:它是一个访问说明符。默认情况下,C++/Java中的实例(成员)变量或类的方法是私有的。在继承过程中,代码和数据总是继承的,但在类外部是不可访问的。我们可以将数据成员声明为私有的,这样就没有人可以直接更改我们的成员变量,并且我们可以提供公共的getter和setter来更改我们的私有成员。这一概念一直在商业规则中应用。
保护:它也是一个访问说明符。在C++中,受保护成员在类和继承类中都是可访问的,但不在类之外。在Java中,受保护的成员在类内、继承的类以及同一包内的所有类都是可访问的。
成员数据首选
根本无法访问
MFC是一个用于Windows API的C++包装器,它更喜欢EDCOX1 2和EDCX1 5。由Visual Studio向导生成的类混合了
像
像
有些成员必须执行线程和消息循环,它们不应该被访问或重写,因此它们被声明为
在C++结构中,默认情况下成员是EDCOX1(2)。结构通常只用于数据,而不是方法,因此
private:可由类成员函数和友元函数或友元类访问。对于C++类,这是默认访问说明符。
保护:可由类成员函数、友元函数或友元类派生类访问。
- 您可以根据需要将类成员变量或函数(甚至typedef或内部类)保持为私有或受保护。
- 大多数时候,您将类成员保持为私有,并添加get/set函数来封装。这有助于代码的维护。
- 一般来说,当您希望保持公共函数模块化或消除重复代码而不是将整个代码写入单个函数时,可以使用私有函数。这有助于代码的维护。
有关详细信息,请参阅此链接。
受保护的非静态基类成员可以由从该基类派生的任何类的成员和朋友访问,方法是使用以下方法之一:
- 指向直接或间接派生类的指针
- 对直接或间接派生类的引用
- 直接或间接派生类的对象
private和protected访问修饰符是一个且相同的修饰符,只有在子(派生)类中的基类范围之外才能访问基类的受保护成员。它也同样适用于继承。但是,使用私有修饰符,只能在基类的作用域或代码中访问基类成员,并且只能在其友元函数""中访问该成员。