继承
继承的概述:
继承是面向对象三大特征之一。可以使得子类具有父类的属性和方法,还可以在子类中重新定义,追加属性和方法。
//创建父类
public class Fu{
public void show(){
System.out.println("show方法被调用");
}
}
//创建子类让子类继承父类
public class Zi extends Fu{
public void method(){
System.out.println("method方法被调用");
}
}
//测试类
public class Demo{
public static void main(String[] args){
Fu f = new Fu();
f.show();
//show方法被调用
Zi z = new Zi();
z.method();
z.show();
//metho方法被调用
//show方法被调用
}
}
继承的好处:
- 提高了代码的复用性
- 提高了代码的维护性
继承的弊端:
- 继承让类与类之间产生了关系,类的耦合性增强了,削弱了子类的独立性
//创建父类
public class Fu{
public int age = 40;
}
//创建子类让子类继承父类
public class Zi extends Fu{
public int height = 175;
public int age = 20;
public void show(){
int age =30;
System.out.println(age);
System.out.println(height);
}
}
//测试类
public class Demo{
public static void main(String[] args){
Zi z = new Zi();
z.show();
}
}
继承中变量的访问特点:
在子类中访问一个变量
- 子类局部范围找
- 子类成员范围找
- 父类成员范围找
- 如果都没有就报错
//创建父类
public class Fu{
public int age = 40;
}
//创建子类让子类继承父类
public class Zi extends Fu{
public int age = 20;
public void show(){
int age =30;
System.out.println(age);
System.out.println(this.age) //访问本类成员变量age
System.out.println(super.age) //访问父类成员变量age
}
}
//测试类
public class Demo{
public static void main(String[] args){
Zi z = new Zi();
z.show();
}
}
super
- this:代表本类对象的引用
- super:代表父类储存空间的标示(父类对象的引用)
关键字 | 访问成员变量 | 访问成员构造方法 | 访问成员方法 |
---|---|---|---|
this | this.成员变量 访问本类成员变量 | this(…) 访问本类构造方法 | this.成员方法(…) 访问本类成员方法 |
super | super.成员变量 访问父类成员变量 | super(…) 访问父类构造方法 | super.成员方法(…) 访问本类成员方法 |
//创建父类
public class Fu{
public Fu(){
System.out.println("Fu中无参构造方法被调用");
}
public Fu(int age){
System.out.println("Fu中带参构造方法被调用");
}
}
//创建子类
public class Zi{
public Zi(){
//super();
System.out.println("Zi中无参构造方法被调用");
}
public Zi(int age){
//super();
System.out.println("Zi中带参构造方法被调用");
}
}
//测试类
public class Demo{
public static void main(String[] args){
Zi z = new Zi();
//输出Fu中无参构造方法被调用
//输出Zi中无参构造方法被调用
Zi z2 = new Zi(age:20);
//输出Fu中无参构造方法被调用
//输出Zi中无参构造方法被调用
//输出Fu中无参构造方法被调用
//输出Zi中带参构造方法被调用
}
}
继承中构造方法的访问特点:
子类中所有的构造方法默认都会访问父类中无参的构造方法,为什么呢?
- 因为子类会继承父类中的数据,可能还会使用父类的数据。所以子类初始化之前,一定要先完成父类数据的初始化
- 每一个子类构造方法的第一条语句默认都是:
super()
如果父类中没有无参构造方法,只有带参构造方法怎么办呢?
- 通过使用super关键字去显示调用父类的带参构造方法
- 在父类中自己提供一个无参构造方法
//创建父类
public class Fu{
public void show(){
System.out.println("Fu中show方法被调用");
}
}
//创建子类让子类继承父类
public class Zi extends Fu{
public void method(){
System.out.println("Zi中method方法被调用");
public void show(){
super.show();
System.out.println("Zi中show方法被调用");
}
}
//测试类
public class Demo{
public static void main(String[] args){
Zi z = new Zi();
z.method();
z.show();
}
}
继承中成员方法的访问特点:
通过子类对象访问一个方法
- 子类成员范围找
- 父类成员范围找
- 如果都没有就报错
方法重写:
方法重写概述
- 子类中出现了和父类一样的方法声明
方法重写的应用
- 当子类需要父类的功能,而功能主体子类有自己特有内容时,可以重写父类中的方法,这时,即沿袭了父类的功能,又定义了子类特有的内容
Override
- 这是一个注解
- 可以帮组我们检查重写方法的方法声明的正确性
//创建手机类
public class Phone{
public void call(String name){
System.out.println("给"+name+“打电话”);
}
}
//创建新手机类继承手机类
/*
public class NewPhpne extends phone {
public void call(String name){
System.out.println("开启视频功能");
// System.out.println("给"+name+“打电话”);
super.call(name);
}
*/
@override
public class NewPhpne extends phone {
public void call(String name){
System.out.println("开启视频功能");
super.call(name);
//手机测试类
public class PhoneDemo {
Phone p = new Phone();
p.call("周杰伦");
NewPhone np = new NewPhone();
np.call("周杰伦");
}
方法重写注意事项:
- 私有方法不能被重写(父类私有成员子类不能继承)
- 子类方法访问权限不能更低(public>默认>私有)
Java中继承的注意事项:
- Java中类☞支持,不支持多继承
- Java中类支持多层继承
修饰符
包的概述和使用
包其实就是文件夹,对类进行分类管理
导包的概述和使用
使用不同包下的类时,使用的时候要写类的全路径,写起来太麻烦了,为了简化带包的操作,Java就提供了导包的功能
权限修饰符
修饰符 | 同一个类中 | 同一个包中子类无关类 | 不同包的子类 | 不同包的无关类 |
---|---|---|---|---|
private | √ | |||
默认 | √ | √ | ||
protected | √ | √ | √ | |
public | √ | √ | √ | √ |
状态修饰符(final、static)
final(最终态):
final关键字是最终的意思,可以修饰成员方法,成员变量,类
final修饰的特点:
- 修饰方法:表明该方法是最终方法,不能被重写
- 修饰变量:表明该变量是常量,不能再次被赋值
- 修饰类:表明该类是最终类,不能被继承
final修饰局部变量
- 变量是基本类型:final修饰指的是基本类型的数据值不能发生改变
变量是引用类型:final修饰指的是引用类型的地址值不能发生改变,但是地址里面的内容是可以发生改变的
static(静态):
static关键字是静态的意思,可以修饰成员方法,成员变量
static修饰的特点:
- 被类的所有对象共享
- 可以通过类名调用
static访问特点
- 非静态的成员方法:能访问静态成员变量、非静态成员变量、静态成员方法、非静态成员方法
- 静态的成员方法:能访问静态成员变量、静态成员方法