Maison > Java > javaDidacticiel > le corps du texte

Comment utiliser le super mot-clé en Java

WBOY
Libérer: 2023-05-12 08:28:05
avant
891 Les gens l'ont consulté

Comment utiliser le super mot-clé en Java

super

super est un mot clé, tout en minuscules.
Super et this sont comparés et étudiés. "this/super." apparaît dans les méthodes d'instance et "this/super()" apparaît dans les constructeurs
this:
(1) Cela peut apparaître dans les méthodes d'instance et les constructeurs. en méthode.
        (2) La syntaxe de this est : "this.", "this()"
          (3) Ceci ne peut pas être utilisé dans les méthodes statiques.
        (4) ceci peut être omis dans la plupart des cas.
(5) Quand cela ne peut-il pas être omis ? Il ne peut pas être omis lors de la distinction entre les variables locales et les variables d'instance.

public void setName(String name){
                    this.name = name;
                }
Copier après la connexion

(6) this() ne peut apparaître que dans la première ligne de la méthode de construction. Il utilise la méthode de construction actuelle pour appeler d'autres méthodes de construction dans "cette classe" dans le but de : réutiliser le code !

super:
                  (1) super peut apparaître dans les méthodes et les constructeurs d'instance.
              (2) La syntaxe de super est : "super.", "super()"
                                  (3) Super ne peut pas être utilisé dans les méthodes statiques.
            (4) super Il peut être omis dans la plupart des cas.
            (5) super. Quand ne peut-on pas l'omettre ?
                (6) super() ne peut apparaître que dans la première ligne de la méthode constructeur. Il utilise la méthode constructeur actuelle pour appeler la méthode constructeur dans la "classe parent". les caractéristiques du type parent. Super () signifie appeler le constructeur de la classe parent via le constructeur de la sous-classe.

Simulez ce scénario dans le monde réel : si vous voulez avoir un fils, vous devez d'abord avoir un père.

Conclusion importante : Lorsque la première ligne d'une méthode de constructeur :
                                                                                                                                                                                                                                       une méthode de construction. Nous devons donc nous assurer que le constructeur non-paramétrique de la classe parent existe.

Remarque : this() et super() ne peuvent pas coexister, ils ne peuvent apparaître que dans la première ligne du constructeur.
Peu importe vos efforts, la méthode de construction de la classe parent sera définitivement exécutée. (100%)
Compréhension initiale de super
Exemple 1 : La classe parent et la sous-classe sont toutes deux des constructions sans paramètre

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的无参构造方法!
*/
Copier après la connexion

Exemple 2 : La classe parent est une construction sans paramètre et la sous-classe est une construction sans paramètre

La classe parent est construite avec des paramètres et la sous-classe est construite sans paramètres. Si vous souhaitez que la sous-classe appelle la méthode de construction de la classe parent, vous devez écrire le super mot-clé et apporter les paramètres correspondants uniquement de cette manière ; Le constructeur de la classe parent doit être appelé. Reportez-vous à la méthode de construction !

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的无参构造方法!
*/
Copier après la connexion

Exemple 3 : this() et super() ne peuvent pas coexister (clé de compréhension)

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的无参构造方法!
*/
Copier après la connexion

Exemple 4 : Comprendre l'exemple de la matriochka

Dans le langage Java, quel que soit l'objet sur lequel il est nouveau, à la fin Le constructeur sans paramètre de la classe Object de l'ancêtre sera définitivement exécuté

. (Le constructeur sans paramètre de la classe Object est en "haut de la pile")

Caractéristiques du haut de la pile : il est appelé en dernier mais est exécuté en premier. Principe du dernier entré, premier sorti. Tout le monde devrait noter :

Lors de l'écriture de code à l'avenir, il est recommandé d'écrire manuellement la méthode de construction sans paramètre d'une classe.
Si le constructeur sans paramètre est perdu, cela peut affecter la "construction des objets de sous-classe".

C'est le processus de poussée et d'éclatement de la pile : la méthode qui entre en premier sera poussée vers le bas de la pile et sortira en dernier ; la méthode qui entre en dernier sera poussée vers le haut de la pile et reviendra. sorti en premier ; et à cause du mot-clé super(), finalement La classe parent doit être en haut de la pile et sortir en premier

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
	}
}
Copier après la connexion

Utilisation de super (paramètre réel)


Utiliser au bon moment : super (liste des paramètres réels);

Remarque : lors de l'exécution du constructeur, une série de Le constructeur de la classe parent est appelé, et le constructeur de la classe parent continue d'appeler le constructeur de sa classe parent, mais en fait seulement un objet est créé !

Réflexion : à quoi sert « super (paramètre réel) » ?

       
Super (paramètre réel) fonctionne comme

 : initialise les caractéristiques de type parent de l'objet actuel. Cela ne crée pas de nouveaux objets. En fait, un seul objet est créé. Que signifie le super mot-clé ? (1) Le super mot-clé représente les caractéristiques de type parent de "l'objet courant" !

(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;
	}
	
}
Copier après la connexion

内存图(重点掌握)

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

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

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

Comment utiliser le super mot-clé en Java

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 + "正在购物!");
	}
}
Copier après la connexion

内存图

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

Comment utiliser le super mot-clé en Java

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

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

 public void setName(String name){
            this.name = name;
        }
Copier après la connexion

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 正在购物
	}
}
Copier après la connexion

内存图

Comment utiliser le super mot-clé en Java

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();

	}
}
Copier après la connexion

使用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!---调用父类的
	}
}
Copier après la connexion

最后小结:super关键字

super peut apparaître dans les méthodes d'instance et les constructeurs.
La syntaxe de super est : "super.", "super()"
Super ne peut pas être utilisé dans les méthodes statiques.
super. Peut être omis dans la plupart des cas.
super. Quand ne peut-on pas l'omettre ?
S'il y a des attributs avec le même nom ou la même méthode dans la classe parent et la sous-classe, si vous souhaitez accéder à la classe parent dans la sous-classe, super ne peut pas être omis.

super() ne peut apparaître que dans la première ligne de la méthode constructeur. La méthode constructeur dans la "classe parent" est appelée via la méthode constructeur actuelle. Le but est : Lors de la création d'un objet de sous-classe, initialisez d'abord le. caractéristiques du type parent .
Utilisation de super :
                                                    en utilisant         en utilisant ​       en utilisant des ' s ' en utilisant des ' jusqu'à ‐ à ‐ ‐‐‐‐‐ ​ ​ ​ ​ ​ à​​
[Appeler la méthode constructeur de la classe des parents]

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:yisu.com
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!