如何理解被 protected 修饰的成员变量?
时间:2022-07-25
本文章向大家介绍如何理解被 protected 修饰的成员变量?,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
被 protected
修饰的成员对于本包和其子类可见:
- 基类的
protected
成员在包内可见 - 若继承了基类的子类与基类不在同一个包中,那么在子类中,子类实例可以访问其从基类继承而来的
protected
方法,不能访问基类中的protected
方法。
/**
* 基类
*/
package com.example.demo.base;
public class ProFather {
protected void f() {
System.out.println("protected father");
}
}
/**
* 与基类处于同一个包的子类
*/
package com.example.demo.base;
public class ProSon1 extends ProFather {
}
/**
* 与基类处于不同包的子类
*/
package com.example.demo.base2;
public class ProSon2 extends ProFather {
}
在基类所在的包中,基类,子类1和子类2都可以访问函数 f()
/**
* 与基类处于同一个包的测试类
*/
package com.example.demo.base;
public class BaseTest {
public static void main(String[] args) {
// 基类可以访问函数f
ProFather father = new ProFather();
father.f();
// 子类1可以访问函数f
ProSon1 son1 = new ProSon1();
son1.f();
// 子类2可以访问函数f
ProSon2 son2 = new ProSon2();
son2.f();
}
}
在不同的包下,基类,子类1和子类2都不能访问函数 f()
,
/**
* 与基类处于不同包的测试类
*/
package com.example.demo.base2;
public class Base2Test {
public static void main(String[] args) {
ProFather father = new ProFather();
// f 方法被保护,在不同的包不可见
father.f(); // error
ProSon1 son1 = new ProSon1();
// f 方法被保护,在不同的包不可见
son1.f(); // error
ProSon2 son2 = new ProSon2();
// f 方法被保护,在不同的包不可见
son2.f(); // error
}
}
在子类2中:
- 基类无法访问函数
f()
- 子类2可以访问函数
f()
/**
* 与基类处于不同包的son2
*/
package com.example.demo.base2;
public class ProSon2 extends ProFather {
protected void f1() {
super.f();
}
public static void main(String[] args) {
ProFather father = new ProFather();
// f 方法被保护,在不同的包不可见
father.f(); // error
ProSon2 son2 = new ProSon2();
// f 方法被 son2 继承,在子类可见
son2.f(); // ok
}
}
如果子类2重写了父类的 f 方法,并用 protected
修饰,那么在子类2所在的包下可以访问。
/**
* 与基类处于不同包的子类2
*/
package com.example.demo.base2;
public class ProSon2 extends ProFather {
@Override
protected void f() {
super.f();
}
public static void main(String[] args) {
ProSon2 son2 = new ProSon2();
// f 方法被 son2 重写,在子类可见
son2.f();
}
}
/**
* 与基类处于不同包的测试类
*/
package com.example.demo.base2;
public class Base2Test {
public static void main(String[] args) {
// f 方法来自于ProSon2在同一个包内可见
son2.f(); // ok
}
}
参考资料
- 一条insert语句导致的性能问题分析(二)(r8笔记第43天)
- dataguard中的密码文件管理(r8笔记第39天)
- Mybatis_day02
- Golang构建HTTP服务(一)--- net/http库源码笔记
- Golang构建HTTP服务(二)--- Handler,ServeMux与中间件
- 使用Let's Encrypt的SSL证书配置HTTPS手记
- Mybatis_day01
- golang 如何验证struct字段的数据格式
- ggolot2 画ROC曲线
- 47. 访问MySql数据库实现增删改查 | 厚土Go学习笔记
- 39. channel管道 | 厚土Go学习笔记
- springmvc学习第二天
- 厚土Go学习笔记 | 38. goroutine轻量级线程
- 厚土Go学习笔记 | 37. 图片(image)生成器
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- TypeScript:React、拖拽、实践!
- 太慢不能忍!CPU又拿硬盘和网卡开刀了!
- 懂了!VMware/KVM/Docker原来是这么回事儿
- CPU明明8个核,网卡为啥拼命折腾一号核?
- 2020-07-22-腾讯云-slb-kubeadm高可用集群搭建
- 2020-07-23-kubernetes集群使用腾讯云cbs块存储
- 十一、详解面向对象
- 十二、面向对象实战之封装拖拽对象
- 数组reduce方法的高级用法
- 十七、详解 ES6 Modules
- 超干货!为了让你彻底弄懂 MySQL 事务日志,我通宵肝出了这份图解!
- 什么情况下不能使用最坏情况评估算法的复杂度?
- Python运算符
- kubeadm高可用集群意外删除一mater节点,重新加入失败
- Chevereto——简介及安装