深入理解C++中public、protected及private用法

 
这篇文章主要介绍了C++中public、protected及private用法,对于C++面向对象程序设计来说是非常重要的概念,需要的朋友可以参考下
 
 

初学C++的朋友经常在类中看到public,protected,private以及它们在继承中表示的一些访问范围,很容易搞糊涂。今天本文就来十分分析一下C++中public、protected及private用法。相信对于大家深入掌握C++程序设计会有很大的帮助。

这里我们首先要明白下面几点。

1.类的一个特征就是封装,public和private作用就是实现这一目的。所以:

用户代码(类外)可以访问public成员而不能访问private成员;private成员只能由类成员(类内)和友元访问。

2.类的另一个特征就是继承,protected的作用就是实现这一目的。所以:

protected成员可以被派生类对象访问,不能被用户代码(类外)访问。


现来看看如下示例:

  1. #include<iostream>
  2. #include<assert.h>
  3. using namespace std;
  4. class A{
  5. public:
  6. int a;
  7. A(){
  8. a1 = 1;
  9. a2 = 2;
  10. a3 = 3;
  11. a = 4;
  12. }
  13. void fun(){
  14. cout << a << endl; //正确
  15. cout << a1 << endl; //正确
  16. cout << a2 << endl; //正确,类内访问
  17. cout << a3 << endl; //正确,类内访问
  18. }
  19. public:
  20. int a1;
  21. protected:
  22. int a2;
  23. private:
  24. int a3;
  25. };
  26. int main(){
  27. A itema;
  28. itema.a = 10; //正确
  29. itema.a1 = 20; //正确
  30. itema.a2 = 30; //错误,类外不能访问protected成员
  31. itema.a3 = 40; //错误,类外不能访问private成员
  32. system("pause");
  33. return 0;
  34. }

继承中的特点:

先记住:不管是否继承,上面的规则永远适用!

有public, protected, private三种继承方式,它们相应地改变了基类成员的访问属性。

1.public继承:基类public成员,protected成员,private成员的访问属性在派生类中分别变成:public, protected, private

2.protected继承:基类public成员,protected成员,private成员的访问属性在派生类中分别变成:protected, protected, private

3.private继承:基类public成员,protected成员,private成员的访问属性在派生类中分别变成:private, private, private

但无论哪种继承方式,上面两点都没有改变:

1.private成员只能被本类成员(类内)和友元访问,不能被派生类访问;

2.protected成员可以被派生类访问。

再来看看以下代码:

1.public继承

代码如下:

  1. #include<iostream>
  2. #include<assert.h>
  3. using namespace std;
  4.  
  5. class A{
  6. public:
  7. int a;
  8. A(){
  9. a1 = 1;
  10. a2 = 2;
  11. a3 = 3;
  12. a = 4;
  13. }
  14. void fun(){
  15. cout << a << endl; //正确
  16. cout << a1 << endl; //正确
  17. cout << a2 << endl; //正确
  18. cout << a3 << endl; //正确
  19. }
  20. public:
  21. int a1;
  22. protected:
  23. int a2;
  24. private:
  25. int a3;
  26. };
  27. class B : public A{
  28. public:
  29. int a;
  30. B(int i){
  31. A();
  32. a = i;
  33. }
  34. void fun(){
  35. cout << a << endl; //正确,public成员
  36. cout << a1 << endl; //正确,基类的public成员,在派生类中仍是public成员。
  37. cout << a2 << endl; //正确,基类的protected成员,在派生类中仍是protected可以被派生类访问。
  38. cout << a3 << endl; //错误,基类的private成员不能被派生类访问。
  39. }
  40. };
  41. int main(){
  42. B b(10);
  43. cout << b.a << endl;
  44. cout << b.a1 << endl; //正确
  45. cout << b.a2 << endl; //错误,类外不能访问protected成员
  46. cout << b.a3 << endl; //错误,类外不能访问private成员
  47. system("pause");
  48. return 0;
  49. }

2.protected继承:

代码如下:

  1. #include<iostream>
  2. #include<assert.h>
  3. using namespace std;
  4. class A{
  5. public:
  6. int a;
  7. A(){
  8. a1 = 1;
  9. a2 = 2;
  10. a3 = 3;
  11. a = 4;
  12. }
  13. void fun(){
  14. cout << a << endl; //正确
  15. cout << a1 << endl; //正确
  16. cout << a2 << endl; //正确
  17. cout << a3 << endl; //正确
  18. }
  19. public:
  20. int a1;
  21. protected:
  22. int a2;
  23. private:
  24. int a3;
  25. };
  26. class B : protected A{
  27. public:
  28. int a;
  29. B(int i){
  30. A();
  31. a = i;
  32. }
  33. void fun(){
  34. cout << a << endl; //正确,public成员。
  35. cout << a1 << endl; //正确,基类的public成员,在派生类中变成了protected,可以被派生类访问。
  36. cout << a2 << endl; //正确,基类的protected成员,在派生类中还是protected,可以被派生类访问。
  37. cout << a3 << endl; //错误,基类的private成员不能被派生类访问。
  38. }
  39. };
  40. int main(){
  41. B b(10);
  42. cout << b.a << endl; //正确。public成员
  43. cout << b.a1 << endl; //错误,protected成员不能在类外访问。
  44. cout << b.a2 << endl; //错误,protected成员不能在类外访问。
  45. cout << b.a3 << endl; //错误,private成员不能在类外访问。
  46. system("pause");
  47. return 0;
  48. }

3.private继承:

代码如下:

  1. #include<iostream>
  2. #include<assert.h>
  3. using namespace std;
  4. class A{
  5. public:
  6. int a;
  7. A(){
  8. a1 = 1;
  9. a2 = 2;
  10. a3 = 3;
  11. a = 4;
  12. }
  13. void fun(){
  14. cout << a << endl; //正确
  15. cout << a1 << endl; //正确
  16. cout << a2 << endl; //正确
  17. cout << a3 << endl; //正确
  18. }
  19. public:
  20. int a1;
  21. protected:
  22. int a2;
  23. private:
  24. int a3;
  25. };
  26. class B : private A{
  27. public:
  28. int a;
  29. B(int i){
  30. A();
  31. a = i;
  32. }
  33. void fun(){
  34. cout << a << endl; //正确,public成员。
  35. cout << a1 << endl; //正确,基类public成员,在派生类中变成了private,可以被派生类访问。
  36. cout << a2 << endl; //正确,基类的protected成员,在派生类中变成了private,可以被派生类访问。
  37. cout << a3 << endl; //错误,基类的private成员不能被派生类访问。
  38. }
  39. };
  40. int main(){
  41. B b(10);
  42. cout << b.a << endl; //正确。public成员
  43. cout << b.a1 << endl; //错误,private成员不能在类外访问。
  44. cout << b.a2 << endl; //错误, private成员不能在类外访问。
  45. cout << b.a3 << endl; //错误,private成员不能在类外访问。
  46. system("pause");
  47. return 0;
  48. }

通过以上的代码都备有较为详尽的注释,读者应该能够理解。仔细看代码中派生类B中定义了和基类同名的成员a,此时基类的a仍然存在,可以验证。

  1. int main(){
  2. cout << sizeof(A) << endl;
  3. cout << sizeof(B) << endl;
  4.  
  5. system("pause");
  6. return 0;
  7. }

输出:

16

20

所以派生类包含了基类所有成员以及新增的成员,同名的成员被隐藏起来,调用的时候只会调用派生类中的成员。

如果要调用基类的同名成员,可以用以下方法:

  1. int main(){
  2.  
  3. B b(10);
  4. cout << b.a << endl;
  5. cout << b.A::a << endl;
  6.  
  7. system("pause");
  8. return 0;
  9. }

输出:

10

4

记得这里是在类外访问,而a在基类中是public,所以继承方式应该为public,使得a在派生类中仍然为public,在类外可以访问。

深入理解C++中public、protected及private用法的更多相关文章

  1. Java访问权限修饰符public protected friendly private用法总结(转载好文Mark)

    首先声明:Java中,friendly这个修饰符并没有显式的声明,在成员变量和方法前什么修饰符也不用,默认的就是friendly.为了条理清晰,分三种不同情况来总结. 一 访问权限修饰符修饰成员变量和 ...

  2. java中public protected friendly private作用域

    1.public:public表明该数据成员.成员函数是对所有用户开放的,所有用户都可以直接进行调用 2.private:private表示私有,私有的意思就是除了class自己之外,任何人都不可以直 ...

  3. 【转】深入理解C++中public、protected及private用法

    首先明白以下两点: 1.类的一个特征就是封装,public和private作用就是实现这一目的. 即:用户代码(类外)可以访问public成员而不能访问private成员:private成员只能由类成 ...

  4. C++中public、protected及private用法

    转自:http://www.jb51.net/article/54224.htm 初学C++的朋友经常在类中看到public,protected,private以及它们在继承中表示的一些访问范围,很容 ...

  5. C++中public,protected,private派生类继承问题和访问权限问题

    C++中public,protected,private派生类继承问题和访问权限问题 当一个子类从父类继承时,父类的所有成员成为子类的成员,此时对父类成员的访问状态由继承时使用的继承限定符决定. 1. ...

  6. java中的 public protected friendly private

    1.public:public表明该数据成员.成员函数是对所有用户开放的,所有用户都可以直接进行调用 2.private:private表示私有,私有的意思就是除了class自己之外,任何人都不可以直 ...

  7. public,protected,friendly,private的访问权限

    请说出作用域public,private,protected,以及不写时的区别 这四个作用域的可见范围如下表所示. 说明:如果在修饰的元素上面没有写任何访问修饰符,则表示friendly. 作用域   ...

  8. java 修饰符的作用一(public protected default private 组)

    1.public protected default private 组 public 权限最大,同类,同包,不同包,同包子类父类之间,不同包子类父类之间都可以访问. java 默认的权限是defau ...

  9. Java学习笔记(4)----Public,Protected,Package,Private修饰符可见性

    Java修饰符类型(public,protected,private,friendly) public的类.类属变量及方法,包内及包外的任何类均可以访问:protected的类.类属变量及方法,包内的 ...

随机推荐

  1. width:100vh与min-height:calc(100vh + 51px)

    vh:相对于视窗的高度,那么vw:则是相对于视窗的高度. “视区”所指为浏览器内部的可视区域大小,即window.innerWidth/window.innerHeight大小,不包含任务栏标题栏以及 ...

  2. Ubuntu/Linux网络配置常用命令

    配置ip 打开配置文件 sudo vim /etc/network/interfaces # This file describes the network interfaces available ...

  3. echarts 折线统计笔记

    效果案例图 需要引入的js文件可以直接去官网下载 下面是代码 <!--第一步: 引入 ECharts 文件 --> <script src="static/js/myjs/ ...

  4. POJ1860-Currency Exchange (正权回路)【Bellman-Ford】

    <题目链接> <转载于 >>> > 题目大意: 有多种汇币,汇币之间可以交换,这需要手续费,当你用100A币交换B币时,A到B的汇率是29.75,手续费是0. ...

  5. POJ 1228 (稳定凸包问题)

    <题目链接> <转载于  >>> > 首先来了解什么是稳定的凸包.比如有4个点: 这四个点是某个凸包上的部分点,他们连起来后确实还是一个凸包.但是原始的凸包可 ...

  6. BZOJ.2034.[2009国家集训队]最大收益(二分图匹配 贪心)

    题目链接 双倍经验:BZOJ.4276.[ONTAK2015]Bajtman i Okrągły Robin(然而是个权限题.区间略有不同) \(Description\) 有\(n\)个任务,完成一 ...

  7. hihocoder 1496 寻找最大值(高维前缀最大次大值)

    [题目链接] https://hihocoder.com/problemset/problem/1496 [题目大意] 给定N个数A1, A2, A3, ... AN, 从中找到两个数Ai和Aj(i≠ ...

  8. COGS.1317.数列操作c(分块 区间加 区间求和)

    题目链接 #include<cmath> #include<cstdio> #include<cctype> #include<algorithm> u ...

  9. 早期(编译器)优化--Java语法糖的味道

    1.泛型与类型擦除 泛型的本质是参数化类型的应用,也就是说所操作的数据类型被指定为一个参数.这种参数类型可以用在类.接口和方法的创建中,分别称为泛型类.泛型接口和泛型方法.在泛型没有出现之前,只能通过 ...

  10. UIView的层次结构–code

    转:http://blog.dongliwei.cn/archives/uiview-tree-code // Recursively travel down the view tree, incre ...