public、private、protected三者访问权限解析

2024-04-07 04:58

本文主要是介绍public、private、protected三者访问权限解析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

#include <iostream>
using namespace std;/**************** private ****************/
// 1-1.能被该类中的函数访问
// 1-2.能被其友元函数访问。
// 1-3.不能被任何其他访问,该类的对象也不能访问。
/**************** protected ****************/
// 2-1.能被该类中的函数访问
// 2-2.能被子类的函数访问
// 2-3.能被其友元函数访问。 
// 2-4.不能被该类的对象访问。
/**************** public ****************/
// 3-1.能被该类中的函数访问
// 3-2.能被子类的函数访问
// 3-3.能被其友元函数访问
// 3-4.能被该类的对象访问。
/****************  默认权限(default) ****************/
// 类,数据成员,构造方法,方法成员,都能够使用默认权限,即不写任何关键字。
// 默认权限即同包权限,同包权限的元素只能在定义它们的类中,以及同包的类中被调用。// 注:友元函数包括3种:设为友元的普通的非成员函数;设为友元的其他类的成员函数;设为友元类中的所有成员函数。class ExpClass
{
public:ExpClass(){};ExpClass(int a):PrivateData(a){}ExpClass(int a, int b):PrivateData(a),PublicData(b){}void fun(int a, int b);friend void fun1(ExpClass f, int a);
private:int PrivateData;
protected:int ProtectedData;
public:int PublicData;
};class SonExpClass : ExpClass
{
public:SonExpClass(){};SonExpClass(int a):SonPrivateData(a){}SonExpClass(int a, int b, int c):SonPrivateData(a),SonProtectedData(b),SonPublicData(c){}void Sonfun(int a, int b);
//	friend void Sonfun1(ExpClass f, int a);
private:int SonPrivateData;
protected:int SonProtectedData;
public:int SonPublicData;
};void ExpClass::fun(int a, int b)
{PrivateData = a+b;   // 1-1.成员函数可以访问private类型cout<<"1-1.成员函数可以访问private类型PrivateData="<<PrivateData<<endl;ProtectedData = a-b; // 2-1.成员函数可以访问private类型cout<<"2-1.成员函数可以访问protected类型ProtectedData="<<ProtectedData<<endl;PublicData = a*b; // 3-1.成员函数可以访问public类型cout<<"3-1.成员函数可以访问public类型PublicData="<<PublicData<<endl;
}void SonExpClass::Sonfun(int a, int b)
{ProtectedData = 10;PublicData = 10;int temp1 = ProtectedData+a+b; // 2-2.子类的函数可以访问protected类型cout<<"2-2.子类的函数可以访问protected类型ProtectedData+"<<a<<"+"<<b<<"="<<temp1<<endl;int temp2 = PublicData+a*b; // 3-2.子类的函数函数可以访问public类型cout<<"3-2.子类的函数可以访问public类型PublicData+"<<a<<"*"<<b<<"="<<temp2<<endl;
}void fun1(ExpClass f, int a)
{int temp1 = a+f.PrivateData;   // 1-2.友元函数可以访问private类型cout<<"1-2.友元函数可以访问private类型"<<a<<"+PrivateData"<<"="<<temp1<<endl;// cout<<a+PrivateData<<endl;// 不能这样访问int temp2 = a-f.ProtectedData;    // 2-3.友元函数可以访问protected类型cout<<"2-3.友元函数可以访问protected类型"<<a<<"-ProtectedData"<<"="<<temp2<<endl;int temp3 = a*f.PublicData;    // 3-3.友元函数可以访问public类型cout<<"3-3.友元函数可以访问public类型"<<a<<"*PublicData"<<"="<<temp3<<endl;
}void main()
{cout<<"************************基类A1************************"<<endl;ExpClass A1(0);A1.fun(5, 3);fun1(A1, 10);// cout<<A1.PrivateData<<endl; // 1-3.错误,private类型变量不能被类的对象所访问// cout<<A1.ProtectedData<<endl; // 2-4.错误,protected类型变量不能被类的对象所访问cout<<"3-4.类的对象可访问public类型A1.PublicData="<<A1.PublicData<<endl;cout<<endl;cout<<"************************子类B1************************"<<endl;SonExpClass B1(0, 0, 0);B1.Sonfun(20, 30);// cout<<B1.PublicData<<endl;  // 子类的对象不能访问父类的public类型变量// B1.fun(1, 2);  // 子类的对象不能访问父类的public类型函数
}


附表:基类成员和基类子对象成员在派生类中的访问权限

派生方式  基类中的访问控制基类的public成员基类的protected成员基类的private成员派生方式引起的访问属性变化概括
private派生变为private成员变为private成员不可见基类中的非私有成员都成为派生类中的私有成员
protected派生变为protected成员变为protected成员不可见基类中的非私有成员在派生类中的访问属性都降一级
public派生仍为public成员仍为protected成员不可见基类中的非私有成员在派生类中的访问属性保持不变

 


这篇关于public、private、protected三者访问权限解析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/881693

相关文章

网页解析 lxml 库--实战

lxml库使用流程 lxml 是 Python 的第三方解析库,完全使用 Python 语言编写,它对 XPath表达式提供了良好的支 持,因此能够了高效地解析 HTML/XML 文档。本节讲解如何通过 lxml 库解析 HTML 文档。 pip install lxml lxm| 库提供了一个 etree 模块,该模块专门用来解析 HTML/XML 文档,下面来介绍一下 lxml 库

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

安卓链接正常显示,ios#符被转义%23导致链接访问404

原因分析: url中含有特殊字符 中文未编码 都有可能导致URL转换失败,所以需要对url编码处理  如下: guard let allowUrl = webUrl.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) else {return} 后面发现当url中有#号时,会被误伤转义为%23,导致链接无法访问

OWASP十大安全漏洞解析

OWASP(开放式Web应用程序安全项目)发布的“十大安全漏洞”列表是Web应用程序安全领域的权威指南,它总结了Web应用程序中最常见、最危险的安全隐患。以下是对OWASP十大安全漏洞的详细解析: 1. 注入漏洞(Injection) 描述:攻击者通过在应用程序的输入数据中插入恶意代码,从而控制应用程序的行为。常见的注入类型包括SQL注入、OS命令注入、LDAP注入等。 影响:可能导致数据泄

从状态管理到性能优化:全面解析 Android Compose

文章目录 引言一、Android Compose基本概念1.1 什么是Android Compose?1.2 Compose的优势1.3 如何在项目中使用Compose 二、Compose中的状态管理2.1 状态管理的重要性2.2 Compose中的状态和数据流2.3 使用State和MutableState处理状态2.4 通过ViewModel进行状态管理 三、Compose中的列表和滚动

Spring 源码解读:自定义实现Bean定义的注册与解析

引言 在Spring框架中,Bean的注册与解析是整个依赖注入流程的核心步骤。通过Bean定义,Spring容器知道如何创建、配置和管理每个Bean实例。本篇文章将通过实现一个简化版的Bean定义注册与解析机制,帮助你理解Spring框架背后的设计逻辑。我们还将对比Spring中的BeanDefinition和BeanDefinitionRegistry,以全面掌握Bean注册和解析的核心原理。

两个月冲刺软考——访问位与修改位的题型(淘汰哪一页);内聚的类型;关于码制的知识点;地址映射的相关内容

1.访问位与修改位的题型(淘汰哪一页) 访问位:为1时表示在内存期间被访问过,为0时表示未被访问;修改位:为1时表示该页面自从被装入内存后被修改过,为0时表示未修改过。 置换页面时,最先置换访问位和修改位为00的,其次是01(没被访问但被修改过)的,之后是10(被访问了但没被修改过),最后是11。 2.内聚的类型 功能内聚:完成一个单一功能,各个部分协同工作,缺一不可。 顺序内聚:

CSP 2023 提高级第一轮 CSP-S 2023初试题 完善程序第二题解析 未完

一、题目阅读 (最大值之和)给定整数序列 a0,⋯,an−1,求该序列所有非空连续子序列的最大值之和。上述参数满足 1≤n≤105 和 1≤ai≤108。 一个序列的非空连续子序列可以用两个下标 ll 和 rr(其中0≤l≤r<n0≤l≤r<n)表示,对应的序列为 al,al+1,⋯,ar​。两个非空连续子序列不同,当且仅当下标不同。 例如,当原序列为 [1,2,1,2] 时,要计算子序列 [

多线程解析报表

假如有这样一个需求,当我们需要解析一个Excel里多个sheet的数据时,可以考虑使用多线程,每个线程解析一个sheet里的数据,等到所有的sheet都解析完之后,程序需要提示解析完成。 Way1 join import java.time.LocalTime;public class Main {public static void main(String[] args) thro