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 同一个 ...
随机推荐
- JavaScript:RegExp 对象
ylbtech-JavaScript:RegExp 对象 1.返回顶部 RegExp 对象 RegExp 对象表示正则表达式,它是对字符串执行模式匹配的强大工具. 直接量语法 /pattern/att ...
- Nuget挂了的解决方法(转)
今天用Nuget下一个程序包时,发现Nuget挂了:未能解析此远程名称:'nuget.org'.第一反应就是方校长抖威风了,挂个代理上 http://nuget.org 试了下,果然好好的. 用命令n ...
- Downloading files from a server to client, using ASP.Net, when file size is too big for MemoryStream using Generic Handlers (ashx)
Currently, I was trying to write an ASP.Net application that involved a user clicking a ASP.Net butt ...
- PyTorch保存模型与加载模型+Finetune预训练模型使用
Pytorch 保存模型与加载模型 PyTorch之保存加载模型 参数初始化参 数的初始化其实就是对参数赋值.而我们需要学习的参数其实都是Variable,它其实是对Tensor的封装,同时提供了da ...
- Centos7 搭建lnmp环境 (centos7+nginx+MySQL5.7.9+PHP7)
阿里云一台服务器出现问题! 我估计是一键安装包环境的原因,所以打算重新搭建下环境! 首先,当然是先做好快照!安全第一! 对系统盘做更换系统操作,装上纯净版的centos. 装好后,进入系统 一.挂载数 ...
- java根据图片路径下载到服务器方案 (转)
http://www.cnblogs.com/thinkingandworkinghard/articles/5589484.html 平常做的工作中,有一部分是同步数据的.但是同步的过程中碰到个问题 ...
- Centos下修改hostname
之前安装Centos时候,没有怎么注意,将自己的名字设置为hostname,总感觉好别扭,很不习惯,如是就想把hostname改一下,用到hostname命令. 首先用hostname命令查看当前的主 ...
- Eclipse Maven项目报错3之找不到配置文件spring-servlet-context.xml
一.具体错误如下图所示 根据文字提示可以看出是这个文件找不到,但是我去项目的这个目录找了,这个文件确实存在,那么是什么问题呢 二.解决问题 原因分析(来自网上) 代码编译的过程,是一个自动生成相应编译 ...
- Managed C++ dll: #define _AFXDLL or do not use /MD[ d]?
[问题] Hello all I'm writing a managed C++ dll with will be acting as an intermediate between a lo ...
- [React] Use React.ReactNode for the children prop in React TypeScript components and Render Props
Because @types/react has to expose all its internal types, there can be a lot of confusion over how ...