设为首页 加入收藏

TOP

java笔记(5)(this,super,override,instanceof,static)(一)
2023-07-25 21:33:48 】 浏览:45
Tags:java 笔记 this super override instanceof static

super关键字的一些注意事项

  1. 子类在执行构造方法时,如果显式使用super()显式调用父类构造方法,则该调用必须放代码块在第一行
  2. super必须出现在子类的方法或者构造方法中
  3. 使用this()显示调用构造方法,则该调用必须放在代码块第一行
  4. 由于第一条和第三条限制,super和this不能同时调用构造方法
class P1{
  public P1(){
    //this(); //不可以递归调用构造方法
  }
  public P1(String str){
    this();//可以调用重载的构造方法,该调用必须放在第一行
  }
}

class S1 extends P1{
  public S1(){
    super();//显式调用父类构造方法,该调用必须放在第一行
  }
  public S1(String str){
    this();//无论调用自己的构造方法还是父类的构造方法,都要求在第一行,因此只能调用其中一个
    System.out.println("constructor with parameter");
  }
}

super 和 this的不同

  1. 代表的对象不同:
  • this:本身调用者这个对象
  • super:代表父类对象的引用
  1. 使用的前提不一样:
  • this没有发生继承也可以使用
  • super只有在发生继承时才可以使用,用来表示父类
  1. 构造方法不一样:
  • this() 调用本类的构造方法
  • super() 调用父类的构造方法

方法重写

方法重写是多态的一个前提,需要在有继承关系的前提下,由子类重写父类的方法,并且存在几点要求:

  1. 方法名必须相同
  2. 参数列表必须相同
  3. 重写的方法修饰符范围可以扩大: public>protected>default>private
  4. 抛出的异常范围可以缩小,但不能扩大:ClassNotFoundException(小) ==> Exception(大)
  5. 返回值类型可以缩小
class P2{
	protected S1 run() throws Exception{
		System.out.println("Father running!");
		return new S1();
	}
}
class S2 extends P2{
//修饰符范围可以扩大,抛出异常范围可以缩小
//子类方法与父类方法方法名、参数列表必须完全一致
	public P1 run() throws ClassNotFoundException{
		System.out.println("Son running!");
		return new P1();//返回值范围可以缩小
	}
}

多态注意事项

  1. 多态是方法的多态,属性没有多态
  2. 如果没有继承关系的类强制转换,会导致ClassCastException类型转换异常
  3. 多态的存在条件:继承关系、方法重写、父类引用指向子类对象, Father f1 = new Son();
    因此,有一些方法是不能实现多态的:
  4. static 方法不能实现多态,因为static方法是属于类的,不属于实例,当子类定义同名static方法时,会隐藏父类的同名方法。
  5. final 修饰的类和方法。因为final修饰的类为最终类,不能被继承,断子绝孙了,不能满足继承关系,自然也就无法实现多态;final修饰的方法不能被重写,也不能实现多态
  6. private 修饰的方法。这类方法子类无法访问,无法产生重写,因此无法产生多态。
  7. 在实验中,父类中 protected 修饰的方法在重写后,只有在父类包路径中可以实现多态,当实例范围超出父类的包之后,该方法即只能被子类实例调用,父类引用指向的子类实例此时不能再调用该方法。
public class Test{
	public static void mail(String args[]) throws Exception{
	S2 stu = new S2();
	stu.run();//无论在哪里都可以正常调用
	P2 per = stu;//父类引用指向子类实例,此时发生多态
	per.run();//只有当Test与父类P2在同一个包中时,父类引用per才可以访问重写的run()方法。
	}
}

类型转换

  1. 当类型由低向高转化时,如子类型转化为夫类型,直接使用父类引用指向子类实例即可。
  2. 当类型由高向低转化时,需要进行强制类型转换。这是因为子类实例一定是父类的实例,包含父类的所有域,而父类实例不一定时子类型的实例,包含的域可能更小。
  3. 子类转换为父类时,可能丢失自己的方法。
class P3{

}
class S3 extends P3{
	static void talk(){
		System.out.println("Son talk sth");
	}

	public class Test{
		public static void main(String[] args){
			S3 son = new S3();
			//此的S3的类方法talk()
			son.talk();
			P3 per = son;//直接使用父类应用指向子类对象,即完成了类型由低到高的转换
			//转换成更高等级的父类后,子类中的talk不能被访问了
			//per.talk()//不能访问
			S3 son1 = (S3)per;//由父类型向子类型转换则需要强制类型转换
		}
	}
}

instanceof

instanceof的作用是判断一个对象是否是某个类型的实例

obj instanceof Class
  1. obj不可以是基本类型,必须是引用类型
  2. obj为null时,结果false
  3. obj为Class的实例对象或子类的实例对象时,结果为ture
  4. obj与Class不在同一条继承树上,不能通过编译
/*
Person类为父类
Student、Teacher继承Person类
Object > Person > Student = Teacher
*/
    Object object = new Student();
    System.out.println(object instanceof Object); //true
    System.out.println(object instanceof Student);//true
    System.out.println(object instanceof Person); //true
    System.out.println(object instanceof Teacher);//false
    System.out.println(object instanceof String); //false
    System.out.println("===================================");
    Person person = new Student();
    System.out.println(person instanceof Object); //true
    System.out.println(person instanceof Person); //true
    System.out.println(person instanceof
首页 上一页 1 2 下一页 尾页 1/2/2
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇Java学习一 下一篇Java 函数式编程「二」

最新文章

热门文章

Hot 文章

Python

C 语言

C++基础

大数据基础

linux编程基础

C/C++面试题目