java笔记(this,super,override,instanceof,static)

Posted hiibird

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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()方法。
	


instanceof

instanceof的作用是判断实例的类型

  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;//由父类型向子类型转换则需要强制类型转换
		
	


static

static在类加载时的一些作用

public class P4
	
		System.out.println("Anonymous code block!");
	
	static 
		System.out.println("Static anonymous code block!");
	
	public P4()
		System.out.println("No parameter constructor!");
	
	public static void main(String[] args)
        P4 per1 = new P4();
        System.out.println("==============");
        P4 per2 = new P4();
	

执行结果如下:

可见静态代码块在类加载时首先执行,且在类生命周期中只被执行一次,而匿名代码块则在构造方法之前执行,且每次实例化都会执行。

JAVA笔记super and this

总结关键字this与super用法。
author: ZJ 07-3-12
1.什么是super?什么是this
super关键字表示超(父)类的意思。this变量代表对象本身。
2.使用super&this调用成员变量和方法
可以使用super访问父类被子类隐藏的变量或覆盖的方法。当前类如果是从超类继承而来的,当调用super.XX()就是调用基类版本的XX()方法。见示例1。
当类中有两个同名变量,一个属于类(类的成员变量),而另一个属于某个特定的方法(方法中的局部变量),使用this区分成员变量和局部变量。见示例2。
 
示例1
class Person {
    protected void print() {
       System.out.println("The print() in class Person.");
    }
}
 
public class DemoSuper extends Person {
    public void print() {
       System.out.println("The print() in class DemoSuper.");
       super.print();// 调用父类的方法
    }
 
    public static void main(String[] args) {
       DemoSuper ds = new DemoSuper();
       ds.print();
    }
}
 
结果:
The print() in class DemoSuper.
The print() in class Person.
 
示例2
public class DemoThis {
    private String name;
 
    public void setName(String name) {
       this.name = name;// 前一个name是private name;后一个name是setName中的参数。
    }
}
3.使用this表示当前调用方法的对象引用
假设你希望在方法的内部获得对当前对象的引用,可使用关键字this。this关键字只能在方法内部使用,表示对“调用方法的那个对象”的引用。见示例3。
 
示例3
Button bn;
bn.addActionListener(this);
4.使用super&this调用构造子
super(参数):调用基类中的某一个构造函数(应该为构造函数中的第一条语句)。见示例4。
this(参数):调用本类中另一种形成的构造函数(应该为构造函数中的第一条语句)。 见示例5。
 
示例4
class Person {
    public static void prt(String s) {
       System.out.println(s);
    }
 
    Person() {
       prt("A Person.");
    }
 
    Person(String name) {
       prt("A person name is:" + name);
    }
}
 
public class Chinese extends Person {
    Chinese() {
       super();// 调用父类构造函数。
       prt("A chinese.");
    }
 
    Chinese(String name) {
       super(name);// 调用父类具有相同形参的构造函数。
       prt("his name is:" + name);
    }
 
    public static void main(String[] args) {
       Chinese cn = new Chinese();
       cn = new Chinese("kevin");
    }
}
 
结果:
A Person.
A chinese.
A person name is:kevin
his name is:kevin
 
示例5
Point(int a,int b){
    x=a;
    y=b;
}
Point(){
    this(1,1); //调用point(1,1),必须是第一条语句。
}
5.使用super&this应该注意些什么?
1)调用super()必须写在子类构造方法的第一行,否则编译不通过。每个子类构造方法的第一条语句,都是隐含地调用super(),如果父类没有这种形式的构造函数,那么在编译的时候就会报错。
 
2)super()和this()类似,区别是,super从子类中调用父类的构造方法,this()在同一类内调用其它方法。
 
3)super()和this()均需放在构造方法内第一行。
 
4)尽管可以用this调用一个构造器,但却不能调用两个。
 
5)this和super不能同时出现在一个构造函数里面,因为this必然会调用其它的构造函数,其它的构造函数必然也会有super语句的存在,所以在同一个构造函数里面有相同的语句,就失去了语句的意义,编译器也不会通过。
 
6)this()和super()都指的是对象,所以,均不可以在static环境中使用。包括:static变量,static方法,static语句块。
 
7)从本质上讲,this是一个指向本对象的指针, 然而super是一个Java关键字。

以上是关于java笔记(this,super,override,instanceof,static)的主要内容,如果未能解决你的问题,请参考以下文章

JAVA基础面试题

技术累积点java23super以及重写重载

Java基础学习笔记九 Java基础语法之this和super

Java继承

Java 自定Thread类中super.run()的作用?

Java学习笔记