C++ primer(十三)--类继承、构造函数成员初始化、虚函数、抽象基类
一、基类
从一个类派生出另一个类时,原始类称为基类,继承类称为派生类。
派生类对自身基类的private成员没有访问权限,对基类对象的protected成员没有访问权限,对派生类对象的(基类之外)的private和protected成员具有访问权限。
由于C++基础不好,平时也不用它,导致今天才纠正一个非常关键的错误,类的访问权限,是对类而言的,而不是对类的对象而言的。一直都理解错了。这句话都没脸写出来,还是写下来了。
下面是一段简答的测试代码。对于调用成员函数的对象test,基类形参,派生类形参三者的访问权限做了测试如下:
#include <iostream>using namespace std;class Grand{public: void public_foo (){}protected: void protected_foo(){}private: void private_foo(){}};class Father:public Grand{public: void f_public_test() {public_foo(); } void f_protected_test() {protected_foo(); } // void f_private_test() {private_foo(); } };class Child:public Father{public: void c_protected_test() {protected_foo(); }// void c_private_test() {private_foo();}};int main( int argc, char* argv[]){ Father objF;// objF.protected_foo(); return 1;} //protected.cpp#include <iostream>using namespace std;class Grand{public: void public_foo (){}protected: void protected_foo(){}private: void private_foo(){}};class Father:protected Grand{public: void f_public_test() {public_foo(); } void f_protected_test() {protected_foo(); } // void f_private_test() {private_foo(); } };class Child:public Father{public: void c_protected_test() {protected_foo(); }// void c_private_test() {private_foo();}};int main( int argc, char* argv[]){ Father objF;// objF.public_foo();// objF.protected_foo(); return 1;}//private.cpp#include <iostream>using namespace std;class Grand{public: void public_foo (){}protected: void protected_foo(){}private: void private_foo(){}};class Father:private Grand{public: void f_public_test() {public_foo(); } void f_protected_test() {protected_foo(); } // void f_private_test() {private_foo(); } };class Child:public Father{public:// void c_protected_test() {protected_foo(); }// void c_private_test() {private_foo();}};int main( int argc, char* argv[]){ Father objF;// objF.public_foo();// objF.protected_foo(); return 1;}