C++中public、protected及private使用方法
1.类的一个特征就是封装,public和private作用就是实现这一目的。所以:
用户代码(类外)能够訪问public成员而不能訪问private成员;private成员仅仅能由类成员(类内)和友元訪问。
2.类的还有一个特征就是继承。protected的作用就是实现这一目的。所以:
protected成员能够被派生类对象訪问,不能被用户代码(类外)訪问。
现来看看例如以下演示样例:
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
34
|
#include<iostream> #include<assert.h> using namespace std;
class A{ public : int a; A(){ a1 = 1; a2 = 2; a3 = 3; a = 4; } void fun(){ cout << a << endl; //正确 cout << a1 << endl; //正确 cout << a2 << endl; //正确,类内訪问 cout << a3 << endl; //正确,类内訪问 } public : int a1; protected : int a2; private : int a3; }; int
A itema; itema.a = 10; //正确 itema.a1 = 20; //正确 itema.a2 = 30; //错误,类外不能訪问protected成员 itema.a3 = 40; //错误,类外不能訪问private成员 system ( "pause" ); return 0; } |
继承中的特点:
先记住:无论是否继承,上面的规则永远适用。
有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
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
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
|
#include<iostream> #include<assert.h> using namespace std;
class A{ public : int a; A(){ a1 = 1; a2 = 2; a3 = 3; a = 4; } void fun(){ cout << a << endl; //正确 cout << a1 << endl; //正确 cout << a2 << endl; //正确 cout << a3 << endl; //正确 } public : int a1; protected : int a2; private : int a3; }; class B : public
public : int a; B( int i){ A(); a = i; } void fun(){ cout << a << endl; //正确,public成员 cout << a1 << endl; //正确,基类的public成员,在派生类中仍是public成员。
cout << a2 << endl; //正确。基类的protected成员,在派生类中仍是protected能够被派生类訪问。
cout << a3 << endl; //错误,基类的private成员不能被派生类訪问。 } }; int
B b(10); cout << b.a << endl; cout << b.a1 << endl; //正确 cout << b.a2 << endl; //错误,类外不能訪问protected成员 cout << b.a3 << endl; //错误,类外不能訪问private成员 system ( "pause" ); return 0; } |
2.protected继承:
代码例如以下:
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
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
|
#include<iostream> #include<assert.h> using namespace std;
class A{ public : int a; A(){ a1 = 1; a2 = 2; a3 = 3; a = 4; } void fun(){ cout << a << endl; //正确 cout << a1 << endl; //正确 cout << a2 << endl; //正确 cout << a3 << endl; //正确 } public : int a1; protected : int a2; private : int a3; }; class B : protected A{ public : int a; B( int i){ A(); a = i; } void fun(){ cout << a << endl; //正确,public成员。
cout << a1 << endl; //正确,基类的public成员,在派生类中变成了protected,能够被派生类訪问。
cout << a2 << endl; //正确。基类的protected成员,在派生类中还是protected,能够被派生类訪问。
cout << a3 << endl; //错误,基类的private成员不能被派生类訪问。 } }; int
B b(10); cout << b.a << endl; //正确。public成员 cout << b.a1 << endl; //错误,protected成员不能在类外訪问。 cout << b.a2 << endl; //错误,protected成员不能在类外訪问。 cout << b.a3 << endl; //错误,private成员不能在类外訪问。 system ( "pause" ); return 0; } |
3.private继承:
代码例如以下:
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
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
|
#include<iostream> #include<assert.h> using namespace std;
class A{ public : int a; A(){ a1 = 1; a2 = 2; a3 = 3; a = 4; } void fun(){ cout << a << endl; //正确 cout << a1 << endl; //正确 cout << a2 << endl; //正确 cout << a3 << endl; //正确 } public : int a1; protected : int a2; private : int a3; }; class B : private
public : int a; B( int i){ A(); a = i; } void fun(){ cout << a << endl; //正确,public成员。
cout << a1 << endl; //正确,基类public成员,在派生类中变成了private,能够被派生类訪问。
cout << a2 << endl; //正确,基类的protected成员,在派生类中变成了private,能够被派生类訪问。
cout << a3 << endl; //错误。基类的private成员不能被派生类訪问。 } }; int
B b(10); cout << b.a << endl; //正确。public成员 cout << b.a1 << endl; //错误,private成员不能在类外訪问。 cout << b.a2 << endl; //错误, private成员不能在类外訪问。
cout << b.a3 << endl; //错误。private成员不能在类外訪问。
system ( "pause" ); return 0; } |
通过以上的代码都备有较为详尽的凝视,读者应该可以理解。细致看代码中派生类B中定义了和基类同名的成员a。此时基类的a仍然存在,可以验证。
1
2
3
4
5
6
7
|
int
cout << sizeof (A) << endl; cout << sizeof (B) << endl; system ( "pause" ); return 0; } |
输出:
16
20
所以派生类包括了基类全部成员以及新增的成员,同名的成员被隐藏起来。调用的时候仅仅会调用派生类中的成员。
假设要调用基类的同名成员。能够用下面方法:
1
2
3
4
5
6
7
8
9
|
int
B b(10); cout << b.a << endl; cout << b.A::a << endl; system ( "pause" ); return 0; } |
输出:
10
4
C++中public、protected及private使用方法的更多相关文章
- java中public protected friendly private作用域
1.public:public表明该数据成员.成员函数是对所有用户开放的,所有用户都可以直接进行调用 2.private:private表示私有,私有的意思就是除了class自己之外,任何人都不可以直 ...
- C++中public,protected,private派生类继承问题和访问权限问题
C++中public,protected,private派生类继承问题和访问权限问题 当一个子类从父类继承时,父类的所有成员成为子类的成员,此时对父类成员的访问状态由继承时使用的继承限定符决定. 1. ...
- java中的 public protected friendly private
1.public:public表明该数据成员.成员函数是对所有用户开放的,所有用户都可以直接进行调用 2.private:private表示私有,私有的意思就是除了class自己之外,任何人都不可以直 ...
- java 修饰符的作用一(public protected default private 组)
1.public protected default private 组 public 权限最大,同类,同包,不同包,同包子类父类之间,不同包子类父类之间都可以访问. java 默认的权限是defau ...
- Java访问权限修饰符public protected friendly private用法总结(转载好文Mark)
首先声明:Java中,friendly这个修饰符并没有显式的声明,在成员变量和方法前什么修饰符也不用,默认的就是friendly.为了条理清晰,分三种不同情况来总结. 一 访问权限修饰符修饰成员变量和 ...
- Java学习笔记(4)----Public,Protected,Package,Private修饰符可见性
Java修饰符类型(public,protected,private,friendly) public的类.类属变量及方法,包内及包外的任何类均可以访问:protected的类.类属变量及方法,包内的 ...
- public,protected,friendly,private的访问权限
请说出作用域public,private,protected,以及不写时的区别 这四个作用域的可见范围如下表所示. 说明:如果在修饰的元素上面没有写任何访问修饰符,则表示friendly. 作用域 ...
- 【java基础】(1)Java的权限修饰符(public,protected,default,private)
访问权限修饰符权限从高到低排列是public ,protected ,default, private. 一.根据“是否是同包”.“是否是子类”分为4中情况+本类 5种情况 二.把 同包中的子类 ...
- java四种权限修饰符(public > protected > (default) > private)
权限修饰符在哪里可以访问 (default) : 表示什么权限修饰符都不写 位置 public protected (default) private 同一个类 yes yes yes yes 同一个 ...
随机推荐
- 网络编程之webclient和httpwebrequest的使用
(1)Lambda表达式 “Lambda表达式”是一个匿名函数,它可以包含表达式和语句,并且可用于创建委托或表达式树类型. 所有 Lambda 表达式都使用 Lambda 运算符 =>,该运算符 ...
- PHP一句话木马研究
最近在研究PHP一句话后门,查阅了很多大佬的博客,并从中衍生出了一些可用的方法. 现总结如下: 方案一:回调函数 回调函数:Callback (即call then back 被主函数调用运算后会返回 ...
- mysql启动报错cannot allocate memory for the buffer pool处理
今天启动mysql服务器时失败了.去/var/log/mysql/查看error.log,报错信息如下: 160123 22:29:26 InnoDB: Initializing buffer poo ...
- Idea 自动导入包的*设置99
作者:Intopass 链接:https://www.zhihu.com/question/35806024/answer/64530300 来源:知乎 著作权归作者所有.商业转载请联系作者获得授权, ...
- Android -- tools
工具属性 Android 有一个专用的XML命名空间,用于使工具可以记录XML文件里的信息,并且在打包程序的进行把信息剥离到不会带来运行时期和下载大小的负面影响的程度. 这个命名空间的 URI 是 h ...
- TCP/UDP常见端口
著名端口 端口号码 / 层 名称 注释 1 tcpmux TCP 端口服务多路复用 5 rje 远程作业入口 7 echo Echo 服务 9 discard 用于连接测试的空服务 11 systat ...
- Linux获取进程执行时间
1.前言 测试一个程序的执行时间,时间包括用户CPU时间.系统CPU时间.时钟时间.之前获取之前时间都是在程序的main函数用time函数实现,这个只能粗略的计算程序的执行时间,不能准确的获取其 ...
- [Functional Programming] Create Reusable Functions with Partial Application in JavaScript
This lesson teaches you how arguments passed to a curried function allow us to store data in closure ...
- Android github XListView 分析(2-3)
本文内容 概述 XListView UML 图 下载 github XListView 概述 我们经常能见到 app 中的 listview 有"下拉更多"和"上拉加载& ...
- tomcat7部署多个web应用不同编码,端口
1个tomcat部署多个web应用可以设置不同编码,端口,server.xml配置如下: <?xml version='1.0' encoding='utf-8'?><Server ...