首页后端开发其他后端知识Java super关键字的基础用法和使用技巧是什么

Java super关键字的基础用法和使用技巧是什么

时间2024-03-25 19:58:03发布访客分类其他后端知识浏览1408
导读:在这篇文章中我们会学习到关于“Java super关键字的基础用法和使用技巧是什么”的知识,小编觉得挺不错的,现在分享给大家,也给大家做个参考,希望对大家学习或工作能有帮助。下面就请大家跟着小编的思路一起来学习一下吧。 super...
在这篇文章中我们会学习到关于“Java super关键字的基础用法和使用技巧是什么”的知识,小编觉得挺不错的,现在分享给大家,也给大家做个参考,希望对大家学习或工作能有帮助。下面就请大家跟着小编的思路一起来学习一下吧。
   

super

super是一个关键字,全部小写。
super和this对比着学习,都是"this/super."出现在实例方法,“this/super()"出现在构造方法当中
this:
(1)this能出现在实例方法和构造方法中。
(2)this的语法是:“this.”、“this()”
(3)this不能使用在静态方法中。
(4)this. 大部分情况下是可以省略的。
(5)this.什么时候不能省略呢? 在区分局部变量和实例变量的时候不能省略。

public void setName(String name){
    
                    this.name = name;

                }
    

(6)this() 只能出现在构造方法第一行,通过当前的构造方法去调用“本类”中其它的构造方法,目的是:代码复用!

super:
(1)super能出现在实例方法和构造方法中。
(2)super的语法是:“super.”、“super()”
(3)super不能使用在静态方法中。
(4)super. 大部分情况下是可以省略的。
(5)super.什么时候不能省略呢?
(6)super() 只能出现在构造方法第一行,通过当前的构造方法去调用“父类”中的构造方法,目的是:创建子类对象的时候,先初始化父类型特征。

super()
表示通过子类的构造方法调用父类的构造方法。
模拟现实世界中的这种场景:要想有儿子,需要先有父亲。
重要的结论:当一个构造方法第一行:
既没有this()又没有super()的话,默认会有一个super();
表示通过当前子类的构造方法调用父类的无参数构造方法。
所以必须保证父类的无参数构造方法是存在的。
注意:this()和super() 不能共存,它们都是只能出现在构造方法第一行
无论是怎样折腾,父类的构造方法是一定会执行的。(百分百的)

super初步理解

例1:父类和子类都是无参构造

public class Test01{

	public static void main(String[] args){
    
		//根据无参构造方法创建对象,肯定会调用无参构造方法!
        //只要对象创建出来就会调用构造方法,并且先调用父类的构造方法,在调用子类的构造方法
		new B();
 
	}

}


class A{

	public A(){
     //无参构造方法
		System.out.println("调用A的无参构造方法!");

	}

}

class B extends A{

	public B(){
     //无参构造方法
		//super();
    //默认这里有一个super()通过子类调用父类的无参构造方法;可省略!
		System.out.println("调用B的无参构造方法!");

	}

}

//结果:我们只创建B对象;结果确实先调用A类的构造方法,才调用B类的构造方法
/*
	调用A的无参构造方法!
	调用B的无参构造方法!
*/

例2:父类是有参构造、子类是无参构造

对父类是有参构造、子类是无参构造;要想子类调用父类的构造方法,必须写上super关键字,并带上对应参数;这样才会调用父类的有参构造方法!

public class Test01{

	public static void main(String[] args){
    
		//根据无参构造方法创建对象,肯定会调用无参构造方法!
		new B();

	}

}


class A{

	// 一个类如果没有手动提供任何构造方法,系统会默认提供一个无参数构造方法。
	// 一个类如果手动提供了一个构造方法,那么无参数构造系统将不再提供。
	public A(int i){
     //有参构造方法
		System.out.println("调用A的有参构造方法!");

	}

}

class B extends A{

	public B(){
     //无参构造方法
		// 父类是有参构造方法,此时默认是是super()就会有问题,
           因为super()只能调用父类无参的无参构造方法
		// 所以此时的super就不能省略;并且写上时要写上参数,
            调用父类的有参构造方法,例如:super(100)
		super(100);
    
		System.out.println("调用B的无参构造方法!");

	}

}

//结果:我们只创建B对象;结果确实先调用A类的构造方法,才调用B类的构造方法
/*
	调用A的有参构造方法!
	调用B的无参构造方法!
*/

例3:this()和super()不能共存(重点理解)

public class Test01{

	public static void main(String[] args){
    
		//根据无参构造方法创建对象,肯定会调用无参构造方法!
		new B();

	}

}


class A{
 //默认继承Object类,class A extends Object
	// 建议手动的将一个类的无参数构造方法写出来。
	public A(){
     //无参构造方法
		//这里也默认有super(),调用的是Object的无参构造方法
		System.out.println("调用A的无参构造方法!");

	}

	public A(int i){
     //有参构造方法
		//这里也默认有super(),调用的是Object的无参构造方法
		System.out.println("调用A的有参构造方法!");

	}

}

class B extends A{

	public B(){
     //无参构造方法
        //通过this去调用B的有参构造方法;而B的有参构造方法默认也有super()!
		this("张三");
     
		System.out.println("调用B的无参构造方法!");

	}

	public B(String name){
     //有参构造方法
		//默认也有super(),去调用A的无参构造
		System.out.println("调用B的有参构造方法!");

	}

}

//最终结果
/*
调用A的无参构造方法!
调用B的有参构造方法!
调用B的无参构造方法!
*/

例4:套娃例题理解

在java语言中不管是是new什么对象,最后老祖宗的Object类的无参数构造方法一定会执行。(Object类的无参数构造方法是处于“栈顶部”

栈顶的特点:最后调用,但是最先执行结束。后进先出原则。
大家要注意:
以后写代码的时候,一个类的无参数构造方法还是建议大家手动的写出来。
如果无参数构造方法丢失的话,可能会影响到“子类对象的构建”。

就是压栈弹栈的过程:最先进去的方法会压到栈底部,最后出来;最后进去的会被压栈到最顶部,最先出来;并且因为super()关键字的原因,最终父类一定是栈的顶部,最先出来

public class SuperTest02{

	public static void main(String[] args){
    
		new C();


	}

}

//----------对于父类A实际上也会调用老祖宗Object类的无参构造
/*
class Object{

	public Object(){
	
	}

}

*/

class A {
 //class A extends Object
	public A(){
     //-------最后调用的;最先结束!
		System.out.println("1");
 //1
	}

}


class B extends A{

	public B(){
    
		System.out.println("2");
 
	}

	public B(String name){
    
		//super();
    默认有
		System.out.println("3");
 // 2
	}

}


class C extends B{

	public C(){
     // -------最先调用的;最后结束!
		this("zhangsan");
    
		System.out.println("4");
//5
	}

	public C(String name){
    
		this(name, 20);
    
		System.out.println("5");
//4
	}

	public C(String name, int age){
    
		super(name);
    
		System.out.println("6");
//3
	}

}
    

super(实参)的用法

在恰当的时间使用:super(实际参数列表);
注意:在构造方法执行过程中一连串调用了父类的构造方法,父类的构造方法又继续向下调用它的父类的构造方法,但是实际上对象只创建了一个!

思考:“super(实参)”到底是干啥的?
super(实参)的作用是初始化当前对象的父类型特征。并不是创建新对象。实际上对象只创建了1个。
super关键字代表什么?
(1)super关键字代表的就是“当前对象”的那部分父类型特征!

(2)我继承了我父亲的一部分特征:
例如:眼睛、皮肤等;super代表的就是“眼睛、皮肤等”。
“眼睛、皮肤等”虽然是继承了父亲的,但这部分是在我身上呢。

public class SuperTest03{

	public static void main(String[] args){
    

		CreditAccount ca1 = new CreditAccount();
     //调用无参构造
		System.out.println(ca1.getActno() + "," +
        ca1.getBalance() + "," + ca1.getCredit());
     //null,0.0,0.0

		CreditAccount ca2 = new CreditAccount("1111", 10000.0, 0.999);
    //调用有参构造
		System.out.println(ca2.getActno() + "," + 
        ca2.getBalance() + "," + ca2.getCredit());
 //1111,10000.0,0.999

	}

}


// 账户
class Account extends Object{
    
	// 属性
	private String actno;
    
	private double balance;


	// 构造方法
	public Account(){
     //对于无参构造,默认会调用super();并且给实列变量赋上缺省初始值
		//super();
    
		//this.actno = null;
    
		//this.balance = 0.0;

	}

	public Account(String actno, double balance){
    
		// super();
    
		this.actno = actno;
    
		this.balance = balance;

	}


	// setter and getter
	public void setActno(String actno){
    
		this.actno = actno;

	}

	public String getActno(){
    
		return actno;

	}

	public void setBalance(double balance){
    
		this.balance = balance;

	}

	public double getBalance(){
    
		return balance;

	}

}


// 信用账户
class CreditAccount extends Account{
    

	// 属性:信誉度(诚信值)
	// 子类特有的一个特征,父类没有。
	private double credit;


//重点在这里-------------------------------写上有参构造方法
	// 分析以下程序是否存在编译错误????
	public CreditAccount(String actno, double balance, double credit){
    

		// 直接访问不行,继承过来的私有的属性,只能通过setter和getter方法进行访问
		/*
		this.actno = actno;
    
		this.balance = balance;
    
		*/

		// 以上两行代码在恰当的位置,正好可以使用:super(actno, balance);
    
		// 通过子类的构造方法调用父类的构造方法。
		super(actno, balance);
     //调用父类的构造方法
		this.credit = credit;

	}



	// 提供无参数的构造方法
	public CreditAccount(){
     //对于无参构造,默认会调用super();并且给实列变量赋上缺省初始值

		//super();
    
		//this.credit = 0.0;

	}


	// setter and getter方法
	public void setCredit(double credit){
    
		this.credit = credit;

	}

	public double getCredit(){
    
		return credit;

	}

	
}

内存图(重点掌握)

对于这个内存图,我们要先理解:

(1)要创建CreditAccount对象,调用无参构造方法,默认有super()会调用它的父类Account;Account的无参构造又默认有super()会调用它的父类Object;

(2)根据栈的特点:后进先出,先开辟Object空间、然后开辟Account空间并把里面的实例变量actno和balance进行初始化、最终才开辟CreditAccount对象的空间并把实例变量credit进行初始化;并且有this指向当前对象的地址;有super指向当前对象的父类特征!

super.使用

this表示当前对象。
super表示的是当前对象的父类型特征。(super是this指向的那个对象中的一块空间。)

super和this都不能出现在静态方法中!

public class SuperTest04{

	public static void main(String[] args){
    
		Vip v = new Vip("张三");
    
		v.shopping();

	}

}

class Customer{
    
	String name;

	public Customer(){
}

	public Customer(String name){
    
		super();
    
		this.name = name;

	}

}

class Vip extends Customer{

	public Vip(){
}

	public Vip(String name){
    
		super(name);

	}

	// super和this都不能出现在静态方法中。
	public void shopping(){
    
		// this表示当前对象。
		System.out.println(this.name + "正在购物!");
    
		// super表示的是当前对象的父类型特征。(super是this指向的那个对象中的一块空间。)
		System.out.println(super.name + "正在购物!");
    
		System.out.println(name + "正在购物!");

	}

}

内存图

this实际上包含着super;this不能使用在static里,所以super更不能!

super.什么时候不能省略(掌握)

“this.”和“super.”大部分情况下都是可以省略的。
this. 什么时候不能省略?

 public void setName(String name){
    
            this.name = name;

        }

super. 什么时候不能省略
java中允许在子类中出现和父类一样的同名变量/同名属性。
父中有,子中又有,如果想在子中访问“父的特征”,super. 不能省略

java是怎么来区分子类和父类的同名属性的?
this.name:当前对象的name属性
super.name:当前对象的父类型特征中的name属性。

public class SuperTest05{

	public static void main(String[] args){
    
		Vip v = new Vip("张三");
    
		v.shopping();

	}

}


class Customer {
    
	String name;
 //-----------------父类中也有name
	public Customer(){
}

	public Customer(String name){
    
		super();
    
		this.name = name;

	}


	public void doSome(){
    
		System.out.println(this.name + " do some!");
    
		System.out.println(name + " do some!");
    
		//错误: 找不到符号-----Object里面没有name
		//System.out.println(super.name + " do some!");

	}

}


class Vip extends Customer{
    

	// 假设子类也有一个同名属性
	// java中允许在子类中出现和父类一样的同名变量/同名属性。
	String name;
 //-----------------子类中也有name

	public Vip(){

	}

	public Vip(String name){
    
		super(name);
     //给父类初始化了,子类并没有进行初始化是null
		// this.name = null;

	}

	public void shopping(){
    
		/*
			java是怎么来区分子类和父类的同名属性的?
				this.name:当前对象的name属性
				super.name:当前对象的父类型特征中的name属性。
		*/
        //----默认访问的是当前对象的name;加super访问的是父类的name
		System.out.println(this.name + "正在购物!");
     // null 正在购物
		System.out.println(super.name + "正在购物!");
     // 张三正在购物
		System.out.println(name + "正在购物!");
 //null 正在购物
	}

}

内存图

super使用时后面必须有一个.

this输出“引用”的时候,会自动调用引用的toString()方法;而super使用后面必须跟一个.,但是super.不是引用,不会自动调用toString()方法!

super 不是引用。super也不保存内存地址,super也不指向任何对象。
super 只是代表当前对象内部的那一块父类型的特征。

this和super都不能使用在static静态方法中。

public class SuperTest06 {


	// 实例方法
	public void doSome(){
    
		System.out.println(this);
    //实际上调用的是this.toString()方法
		// 输出“引用”的时候,会自动调用引用的toString()方法。
		//System.out.println(this.toString());
    

		//编译错误: 需要'.'
		//System.out.println(super);

	}


// this和super不能使用在static静态方法中。
	/*
	public static void doOther(){
    
		System.out.println(this);
    
		System.out.println(super.xxx);

	}

	*/

	// 静态方法,主方法
	public static void main(String[] args){
    
		SuperTest06 st = new SuperTest06();
    
		st.doSome();


	}

}

使用super调用父类方法

在父和子中有同名的属性,或者说有相同的方法,
如果此时想在子类中访问父中的数据,必须使用“super.”加以区分。

super.属性名 【访问父类的属性】;super.方法名(实参) 【访问父类的方法】;在子类的实例属性/方法当中调用父类的实例属性/方法
super(实参) 【调用父类的构造方法】

public class SuperTest07{

	public static void main(String[] args){
    
		/*
			Cat move!
			Cat move!
			Animal move!
		*/
		Cat c = new Cat();
    
		c.yiDong();

	}

}


class Animal{

	public void move(){
     //父中有
		System.out.println("Animal move!");

	}

}


class Cat extends Animal{

	// 对move进行重写。
	public void move(){
     //子中也有
		System.out.println("Cat move!");

	}


	// 在子类的实例方法当中调用父类的实例方法
	public void yiDong(){
    
		this.move();
    //Cat move!---调用自己的
		move();
    //Cat move!---调用自己的
		// super. 不仅可以访问属性,也可以访问方法。
		super.move();
//Animal move!---调用父类的
	}

}
    

最后小结:super关键字

super能出现在实例方法和构造方法中。
super的语法是:“super.”、“super()”
super不能使用在静态方法中。
super. 大部分情况下是可以省略的。
super.什么时候不能省略呢?
父类和子类中有同名属性,或者同样的方法,想在子类中访问父类的,super. 不能省略。

super() 只能出现在构造方法第一行,通过当前的构造方法去调用“父类”中的构造方法,目的是:创建子类对象的时候,先初始化父类型特征
super的使用:
(1)super.属性名 【访问父类的属性】
(2)super.方法名(实参) 【访问父类的方法】
(3)super(实参) 【调用父类的构造方法】


关于“Java super关键字的基础用法和使用技巧是什么”的内容就介绍到这,感谢各位的阅读,相信大家对Java super关键字的基础用法和使用技巧是什么已经有了进一步的了解。大家如果还想学习更多知识,欢迎关注网络,小编将为大家输出更多高质量的实用文章!

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!


若转载请注明出处: Java super关键字的基础用法和使用技巧是什么
本文地址: https://pptw.com/jishu/653004.html
PHP里数值类型转布尔类型有什么方法? Java异常原因有几种情况,异常处理怎样做

游客 回复需填写必要信息