ホームページ >Java >&#&チュートリアル >Javaでsuperキーワードを使用する方法
例 1: 親クラスとサブクラスは両方ともパラメーターなしの構造ですsuper はキーワードであり、すべて小文字です。
Super と this を比較検討します。インスタンスメソッドには this/super. が、コンストラクタには this/super() が両方登場します。
this:
( 1) これはインスタンス メソッドとコンストラクターに現れる可能性があります。
(2) this の構文は次のとおりです: "this.", "this()"
(3) これは静的メソッドでは使用できません。
(4) this. これはほとんどの場合省略できます。
(5) これを省略できないのはどのような場合ですか?ローカル変数とインスタンス変数を区別する場合は省略できません。public void setName(String name){ this.name = name; }(6) this() は構築メソッドの最初の行にのみ表示できます。コードの再利用を目的として、現在の構築メソッドを使用して「このクラス」内の他の構築メソッドを呼び出します。
super:
(1) super はインスタンス メソッドおよびコンストラクター内に使用できます。
(2) super の構文は「super.」、「super()」
(3) Super は静的メソッドでは使用できません。
(4) super. ほとんどの場合省略可能です。
(5) スーパー。省略できないのはどのような場合ですか?
(6) super() はコンストラクター メソッドの最初の行にのみ使用できます。現在のコンストラクター メソッドを通じて「親クラス」のコンストラクター メソッドを呼び出します。目的は次のとおりです: サブクラス オブジェクトを作成するとき、最初に初期化します 親タイプの特性。super()
スーパーの初期理解
は、サブクラスのコンストラクターを介して親クラスのコンストラクターを呼び出すことを意味します。
このシナリオを現実世界でシミュレートしてください。息子が欲しい場合は、まず父親が必要です。
重要な結論: コンストラクター メソッドの最初の行:
this() も super() も存在しない場合、デフォルトで super() が存在します; コンストラクターは親クラスのパラメーターなしのコンストラクターを呼び出します。
したがって、 は、親クラスの非パラメーター コンストラクターの数が存在することを確認する必要があります。
注: this() と super() は共存できません。コンストラクターの最初の行にのみ指定できます。 どんなに頑張っても、親クラスの構築メソッドは必ず実行されます。 (100%)
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的无参构造方法!
*/
親クラスはパラメータ化された構成体で、サブクラスはパラメータなしの構成体です。サブクラスが必要な場合は、親クラスのコンストラクターを呼び出すには、 super キーワードを記述し、対応するパラメーターを指定する必要があります。そうすることで初めて、親クラスのパラメーター化されたコンストラクターが呼び出されます。
例 3: this() と 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的无参构造方法! */
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的无参构造方法!
*/
##Java 言語では、それがどのようなオブジェクトであっても、祖先の Object クラスのパラメータなしのコンストラクターは必ず実行されます。 (Object クラスのパラメーターなしのコンストラクターは「スタックの最上位」にあります)
スタックの最上位の特徴: 最後に呼び出されますが、実行は最初に終了します。後入れ先出しの原則。適切なタイミングで使用してください: super(実際のパラメーター リスト); 注: コンストラクター メソッドの実行中に、一連の呼び出しが親クラスのコンストラクター メソッドが呼び出され、親クラスのコンストラクター メソッドがその親クラスのコンストラクター メソッドを呼び出し続けますが、実際には上記のオブジェクトのうち 1 つだけが作成されます。誰もが注意すべきこと: 今後コードを記述するときは、クラスのパラメーターなしの構築メソッドを手動で記述することをお勧めします。 パラメータのないコンストラクタが失われると、「サブクラス オブジェクトの構築」に影響を与える可能性があります。
はスタックのプッシュとポップのプロセスです。最初に入るメソッドはスタックの一番下にプッシュされ、最後に出されます。最後に入るメソッドはスタックの一番上にプッシュされます。スタックして最初に出てくる; そして 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 つだけ作成されます。(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指向当前对象的父类特征!
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更不能!
“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 正在购物 } }
内存图
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(实参) 【调用父类的构造方法】
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() はコンストラクター メソッドの最初の行にのみ指定でき、現在のコンストラクター メソッドを使用して、次の目的で「親クラス」のコンストラクター メソッドを呼び出します。 サブクラスの作成 オブジェクトを使用する場合、まず親の型特性を初期化します。
スーパーの使用:
を使用して を使用して’ ‐ ’ s ’ s ‐ ‐ ‐ ( super(実パラメータ)
[親クラスのコンストラクタを呼び出す]
以上がJavaでsuperキーワードを使用する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。