>  기사  >  Java  >  Java에서 super 키워드를 사용하는 방법

Java에서 super 키워드를 사용하는 방법

WBOY
WBOY앞으로
2023-05-12 08:28:05931검색

Java에서 super 키워드를 사용하는 방법

super

super는 키워드이며 모두 소문자입니다.
Super와 this는 둘 다 인스턴스 메서드에 나타나고 "this/super()"는 생성자에 나타납니다.
this: (1) 이는 인스턴스 메서드와 생성자에 나타날 수 있습니다. 방법.
        (2) this의 구문은 "this.", "this()"입니다.
          (3) This는 정적 메서드에서 사용할 수 없습니다.
        (4) 이는 대부분의 경우 생략 가능합니다.
(5) 언제 생략할 수 없나요? 지역변수와 인스턴스변수를 구분할 때 생략할 수 없습니다.

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()는 공존할 수 없으며 생성자의 첫 번째 줄에만 나타날 수 있습니다.
아무리 노력해도 부모 클래스의 구성 방법은 반드시 실행됩니다. (100%)

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 언어에서는 어떤 객체이든 새로운 객체입니다. , 결국 조상의 Object 클래스의 매개변수 없는 생성자가 반드시 실행될 것입니다. (Object 클래스의 매개변수 없는 생성자는 "스택의 상단"에 있습니다.)

스택 상단의 특징: 마지막으로 호출되지만 먼저 실행됩니다. 후입선출 원칙. 모두가 참고해야 할 사항: 나중에 코드를 작성할 때는 매개변수 없는 클래스 생성 방법을 수동으로 작성하는 것이 좋습니다.

매개변수 없는 생성자가 손실되면 "하위 클래스 객체 생성"에 영향을 미칠 수 있습니다.

스택을 밀고 터뜨리는 과정입니다. 먼저 들어간 메소드는 스택의 맨 아래로 푸시되고 마지막으로 나오는 메소드는 스택의 맨 위로 푸시되어 나옵니다. 먼저 out; 그리고 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(실제 매개변수)는 다음과 같이 작동합니다.
: 현재 객체의 상위 유형 특성을 초기화합니다. 새로운 객체를 생성하지 않습니다. 실제로는 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指向当前对象的父类特征!

Java에서 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更不能!

Java에서 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 正在购物
	}
}

内存图

Java에서 super 키워드를 사용하는 방법

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 사용법:
                                                    using         using         using ​       ’s ’ through ’s ’ 사용 통해 ’s ’ through ‐to ‐ ‐‐‐‐‐ ​ ​ ​ ​ ​ to​
[생성자 메서드 호출 상위 클래스]

위 내용은 Java에서 super 키워드를 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 yisu.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제