찾다
Javajava지도 시간Java에서 super 키워드를 사용하는 방법

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 亿速云에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
고급 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 또는 Gradle을 어떻게 사용합니까?고급 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 또는 Gradle을 어떻게 사용합니까?Mar 17, 2025 pm 05:46 PM

이 기사에서는 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 및 Gradle을 사용하여 접근 방식과 최적화 전략을 비교합니다.

적절한 버전 및 종속성 관리로 Custom Java 라이브러리 (JAR Files)를 작성하고 사용하려면 어떻게해야합니까?적절한 버전 및 종속성 관리로 Custom Java 라이브러리 (JAR Files)를 작성하고 사용하려면 어떻게해야합니까?Mar 17, 2025 pm 05:45 PM

이 기사에서는 Maven 및 Gradle과 같은 도구를 사용하여 적절한 버전 및 종속성 관리로 사용자 정의 Java 라이브러리 (JAR Files)를 작성하고 사용하는 것에 대해 설명합니다.

카페인 또는 구아바 캐시와 같은 라이브러리를 사용하여 자바 애플리케이션에서 다단계 캐싱을 구현하려면 어떻게해야합니까?카페인 또는 구아바 캐시와 같은 라이브러리를 사용하여 자바 애플리케이션에서 다단계 캐싱을 구현하려면 어떻게해야합니까?Mar 17, 2025 pm 05:44 PM

이 기사는 카페인 및 구아바 캐시를 사용하여 자바에서 다단계 캐싱을 구현하여 응용 프로그램 성능을 향상시키는 것에 대해 설명합니다. 구성 및 퇴거 정책 관리 Best Pra와 함께 설정, 통합 및 성능 이점을 다룹니다.

캐싱 및 게으른 하중과 같은 고급 기능을 사용하여 객체 관계 매핑에 JPA (Java Persistence API)를 어떻게 사용하려면 어떻게해야합니까?캐싱 및 게으른 하중과 같은 고급 기능을 사용하여 객체 관계 매핑에 JPA (Java Persistence API)를 어떻게 사용하려면 어떻게해야합니까?Mar 17, 2025 pm 05:43 PM

이 기사는 캐싱 및 게으른 하중과 같은 고급 기능을 사용하여 객체 관계 매핑에 JPA를 사용하는 것에 대해 설명합니다. 잠재적 인 함정을 강조하면서 성능을 최적화하기위한 설정, 엔티티 매핑 및 모범 사례를 다룹니다. [159 문자]

Java의 클래스로드 메커니즘은 다른 클래스 로더 및 대표 모델을 포함하여 어떻게 작동합니까?Java의 클래스로드 메커니즘은 다른 클래스 로더 및 대표 모델을 포함하여 어떻게 작동합니까?Mar 17, 2025 pm 05:35 PM

Java의 클래스 로딩에는 부트 스트랩, 확장 및 응용 프로그램 클래스 로더가있는 계층 적 시스템을 사용하여 클래스로드, 링크 및 초기화 클래스가 포함됩니다. 학부모 위임 모델은 핵심 클래스가 먼저로드되어 사용자 정의 클래스 LOA에 영향을 미치도록합니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경