方法重载、方法重写、四种权限修饰、JavaBean、代码块
方法重载(overload)
- 一个类中可以含有多个重名的方法。
两同一不同
①同一个类
②同一个方法名
③不同参数列表:参数个数不同,参数类型不同

方法重写(override)
- ①子类重写的方法的修饰符大于等于 父类的权限修饰符
- ②子类不能重写父类中private的修饰符
- ③父类的被重写的方法的返回值类型是void,则子类重写的父类中方法的返回值类型是void,
父类的被重写的方法的返回值类型是A,则子类重写的方法返回值类型是A或A的子类,
父类的被重写的方法的返回值类型是基本类型,则子类重写的方法的返回值类型是 相同的基本类型。 - ④子类重写的方法抛出的异常必须小于等于父类被重写的异常
- ⑤父类被重写的方法需要是 非静态的方法,这时可以考虑重写。
四种权限修饰
| 修饰符 | 类内部 | 同一个包 | 不同包子类 | 同一个工程 |
|---|---|---|---|---|
| private | √ | |||
| (缺省) | √ | √ | ||
| protected | √ | √ | √ | |
| public | √ | √ | √ | √ |
| 对于class类只能用public和缺省来修饰 |
javaBean
- javaBean: 类是公共的、有一个无参的公共的构造器、有属性,且有对应的set和get方法。
代码块
- 静态代码块:
①随着类的加载而执行,且只执行一次
②静态代码块可以定义多个,且按照声明的先后顺序执行
③静态代码块内只能调用静态属性、方法 - 非静态代码块
①随着对象的创建而执行,创建一个对象,执行一次
②非静态代码块可以定义多个,且按照声明的先后顺序执行
③非静态代码块可以调用静态和非静态属性和方法
没有继承的初始化顺序


有继承的初始化顺序


class Person{
String name;
int age;
static String dec;
public Person(){
}
public Person(String name, int age){
this.name = name;
this.age = age;
}
//静态代码块
static{
System.out.println("静态代码块");
}
//非静态代码块
{
System.out.println("非静态代码块");
}
public void info1(){
System.out.println("info1");
}
public static void info2(){
System.out.println("info2");
}
}
/** 测试
Test1
Person.dec = "abc";
则结果输出:静态代码块
Test2
Person person = new Person();
则结果输出:
静态代码块
非静态代码块
Test3
Person person = new Person();
Person person2 = new Person();
输出结果:
静态代码块
非静态代码块
非静态代码块
*/
练习一
package com.hyq;
public class Test {
public static void main(String[] args) {
new Leaf();
System.out.println();
//new Leaf();
}
}
class Root{
static {
System.out.println("Root的静态代码块");
}
{
System.out.println("Root的非静态代码块");
}
public Root(){
System.out.println("Root的无参构造器");
}
}
class Mid extends Root{
static {
System.out.println("Mid的静态代码块");
}
{
System.out.println("Mid的非静态代码块");
}
public Mid(){
System.out.println("Mid的无参构造器");
}
public Mid(String msg){
this();
System.out.println("Mid的有参构造器,参数="+msg);
}
}
class Leaf extends Mid{
static {
System.out.println("Leaf的静态代码块");
}
{
System.out.println("Leaf的非静态代码块");
}
public Leaf(){
super("啦啦啦");
System.out.println("Leaf的构造器");
}
}
//super没有显式写明的话,默认调用的是无参构造器。
/** 一个new Leaf()的输出结果:
Root的静态代码块
Mid的静态代码块
Leaf的静态代码块
Root的非静态代码块
Root的无参构造器
Mid的非静态代码块
Mid的无参构造器
Mid的有参构造器,参数=啦啦啦
Leaf的非静态代码块
Leaf的构造器
*/
/** 2个new Leaf()的输出结果:
Root的静态代码块
Mid的静态代码块
Leaf的静态代码块
Root的非静态代码块
Root的无参构造器
Mid的非静态代码块
Mid的无参构造器
Mid的有参构造器,参数=啦啦啦
Leaf的非静态代码块
Leaf的构造器
Root的非静态代码块
Root的无参构造器
Mid的非静态代码块
Mid的无参构造器
Mid的有参构造器,参数=啦啦啦
Leaf的非静态代码块
Leaf的构造器
*/
方法重载、方法重写、四种权限修饰、JavaBean、代码块的更多相关文章
- Java四种权限修饰符 在创建类中的使用
四种权限修饰符 Java中有四种权限修饰符 public > protected > (default) >private 同一个类(我自己) YES YES YES YES同一个包 ...
- java 基础 四种权限修饰符
/** * Java有四种权限修饰符: * public > protected > (default) > private * 同一个类 YES YES YES YES * 同一个 ...
- 阶段1 语言基础+高级_1-3-Java语言高级_02-继承与多态_第6节 权限修饰符_6_四种权限修饰符
四种权限修饰符.从大到小 纵向再分成四种情况 同一个类 同一个类里面.private方式,可以访问到本类里面的 num成员变量 前面不写修饰符也能访问到 (default)就是不写的这种情况 受保护的 ...
- Java 四种权限修饰符
Java 四种权限修饰符访问权限 public protected (default) private 同一个类(我自己) yes yes yes yes 同一包(我邻居) yes yes yes n ...
- Java四种权限修饰符
四种权限修饰符
- Java中的四种权限修饰符及六种非访问修饰符(简识)
一.是哪四种访问权限修饰符呢? public > protected > [default] > private (公共的 ) (受保护的) (默认的) (私有的) 二.简单认识四种 ...
- Java 中的四种权限修饰符
* * private: * Java语言中对访问权限限制的最窄的修饰符,一般称之为“私有的”. * 被其修饰的属性以及方法只能被该类的对象 访问,其子类不能访问,更不能允许跨包访问. * * def ...
- Java的四种权限修饰符
private:仅对本类可见 缺省(不需修饰符):对本包可见 protected:对本包及所有子类可见 public:对所有类可见 修饰符: * 权限修饰符:private,默认的,protected ...
- java四种权限修饰符(public > protected > (default) > private)
权限修饰符在哪里可以访问 (default) : 表示什么权限修饰符都不写 位置 public protected (default) private 同一个类 yes yes yes yes 同一个 ...
随机推荐
- java四种访问修饰符及各自的权限
1.public,即共有的,是访问权限限制最宽的修饰符.被public修饰的类.属性.及方法不仅可以跨类访问,而且可以跨包访问. 2. protected,即保护访问权限,是介于public和priv ...
- SpringCloudAlibaba注册中心与配置中心之利器Nacos实战与源码分析(上)
不断踩坑并解决问题是每个程序员进阶到资深的必要经历并以此获得满足感,而不断阅读开源项目源码和总结思想是每个架构师成长最佳途径.本篇拉开SpringCloud Alibaba最新版本实战和原理序幕,以工 ...
- 安卓记账本开发学习day10
完成了最后一部分功能 1.柱状分析每月的支出或收入 2. 删除所有记录
- 用 getElementsByTagName() 来获取,父元素指定的子元素
1. html 结构 <ul> <li>知否知否,应是等你好久11</li> <li>知否知否,应是等你好久11</li> <li&g ...
- for in 语法遍历对象
1. 语法格式 for (变量 in 对象) { console.log(变量) } 2. 代码实例 // 遍历对象 var obj = { name: 'pink老师', age: 18, se ...
- Java8 新特性,打破你对接口的认知
Java 8 之前,接口里面只能写抽象方法,不能写实现方法 Java 8 开始是可以有方法实现的,可以在接口中添加默认方法和静态方法 默认方法用 default 修饰,只能用在接口中,静态方法用 st ...
- XCTF练习题---WEB---xff_referer
XCTF练习题---WEB---xff_referer flag:cyberpeace{9626408a4b37eab65854d8ccd22f671c} 解题步骤: 1.观察题目,打开场景 2.注意 ...
- Python 树表查找_千树万树梨花开,忽如一夜春风来(二叉排序树、平衡二叉树)
什么是树表查询? 借助具有特殊性质的树数据结构进行关键字查找. 本文所涉及到的特殊结构性质的树包括: 二叉排序树. 平衡二叉树. 使用上述树结构存储数据时,因其本身对结点之间的关系以及顺序有特殊要求, ...
- SpringCloud微服务实战——搭建企业级开发框架(四十):使用Spring Security OAuth2实现单点登录(SSO)系统
一.单点登录SSO介绍 目前每家企业或者平台都存在不止一套系统,由于历史原因每套系统采购于不同厂商,所以系统间都是相互独立的,都有自己的用户鉴权认证体系,当用户进行登录系统时,不得不记住每套系统的 ...
- 常见的邮箱服务器(SMTP,POP3)地址,端口
163.com: POP3服务器地址:pop.163.com(端口:110) SMTP服务器地址:smtp.163.com(端口:25) sina.com: POP3服务器地址:pop3.sina.c ...