この記事では、java に関する関連知識を提供します。主に、このキーワードとスーパー イン キーワードに関する関連する問題と、それらの違いのいくつかを紹介します。一緒に見てみましょう。助けなければなりません。
## 推奨学習: 「Java ビデオ チュートリアル 」
## 1. 「this」キーワードの使用
this2. 関数キーワードは理解するのが難しく、その機能は「現在」を意味するその意味に非常に近いです。
thisキーワードは、プロパティ、メソッド、コンストラクターの変更と呼び出しに使用できます。
3. 使用this
キーワードはメソッド内でのみ使用できます。これはメソッド内で使用されます。つまり、このメソッドが属するオブジェクトへの参照です。
これはコンストラクター内で使用され、コンストラクターによって初期化されるオブジェクトを示します。
thisを使用します。具体的:
3.1 属性とメソッドの変更this
を使用して、プロパティとローカル変数を区別できます。例:this.name = name;
thisは次のように理解されます。現在のオブジェクトまたは現在作成中のオブジェクト
コードのデモ:クラスのメソッドでは、
this.property
またはthis.method
を使用して、現在のオブジェクトのプロパティまたはメソッドを呼び出すことができます。ただし、通常はthis.
を省略することを選択します。特殊なケースでは、メソッドの仮パラメータがクラスの属性と同じ名前である場合、明示的にthis.variable
を使用して、変数が仮パラメータではなく属性であることを示す必要があります。this
を使用してプロパティやメソッドにアクセスする場合、このクラス内にプロパティやメソッドが見つからない場合は、親クラスから検索されます。
class Person{ // 定义Person类 private String name ; private int age ; public Person(String name,int age){ this.name = name ; this.age = age ; } public void getInfo(){ System.out.println("姓名:" + name) ; this.speak(); } public void speak(){ System.out.println(“年龄:” + this.age); } }3.2 コンストラクターの呼び出し
this.methodを明示的に使用して、このクラスで指定されている他のコンストラクターを呼び出すことができます。は、現在作成されているオブジェクトのプロパティまたはメソッドを呼び出します。ただし、通常は
this (仮パラメーター リスト)this.
を省略することを選択します。特殊なケースでは、コンストラクターの仮パラメーターがクラスの属性と同じ名前を持つ場合は、明示的にthis.variable
を使用して、変数が仮パラメーターではなく属性であることを示す必要があります。クラスのコンストラクターでは、
メソッドを通じて独自のコンストラクターを呼び出すことはできません。this (仮パラメーター リスト)
コンストラクターは、
最大でも n - 1 個あります
クラス内に n 個のコンストラクターがある場合、
これ (仮パラメータ リスト)# がコンストラクターで使用されます現在のコンストラクタの最初の行は、
## 規則:
this (仮パラメータリスト)
で宣言する必要があります。this (仮パラメーター リスト)は、他のコンストラクターを呼び出すために使用される
コンストラクター内で、
を最大 1 つだけ宣言できます。
コンストラクターを除き、コンパイラーは他のメソッドでコンストラクターを呼び出すことを禁止します。
コード デモ:3.3 現在のオブジェクトを返すclass Person{ // 定义Person类 private String name ; private int age ; public Person(){ // 无参构造器 System.out.println("新对象实例化") ; } public Person(String name){ this(); // 调用本类中的无参构造器 this.name = name ; } public Person(String name,int age){ this(name) ; // 调用有一个参数的构造器 this.age = age; } public String getInfo(){ return "姓名:" + name + ",年龄:" + age ; } }
コード デモ:
public class Leaf { int i = 0; Leaf increment(){ i++; return this; } void print(){ System.out.println("i = "+i); } public static void main(String args[]){ Leaf x = new Leaf(); x.increment().increment().increment().print();//i = 3 }}
1. 概要
は、定義された ## にアクセスするために使用できます。親クラス #Attributessuper
(2) Java クラスで super を使用して、親クラスで指定された操作を呼び出します。
内。
super
は、親クラスで定義された メンバー メソッド を呼び出すために使用できます。super
を使用すると、サブクラス コンストラクターで親クラスの
constructor を呼び出すことができます。 特に、同じ名前のメンバーが子クラスまたは親クラスに出現する場合、
superを使用して、親クラスのメンバーが呼び出されていることを示すことができます。 ## は直接の親クラスに限定されません。
super の使用法は
thisと似ています。
thisはこのクラス オブジェクトの参照を表し、
super
はメモリを表します親クラスのロゴのスペース。2.
を使用して、サブクラス内の親クラスの構造を明示的に呼び出します。
我们可以在子类的方法或构造器中。通过使用"
super.属性
“或”super.方法
“的方式,显式的调用父类中声明的属性或方法。但是,通常情况下,我们习惯省略”super.
"。
当子类和父类中定义了同名的属性时,我们要想在子类中调用父类中声明的属性,则必须显式的使用"
super.属性
"的方式,表明调用的是父类中声明的属性。
当子类重写了父类中的方法以后,我们想在子类的方法中调用父类中被重写的方法时,则必须显式的使用"
super.方法
"的方式,表明调用的是父类中被重写的方法。
(1)子类中所有的构造器默认都会访问父类中空参数的构造器。
(2)当父类中没有空参数的构造器时,子类的构造器必须通过this(参数列表)或者super(参数列表)语句指定调用本类或者父类中相应的构造器,否则编译出错。同时,只能”二选一”,不能同时出现,且必须放在构造器的首行。
(3)在类的多个构造器中,至少有一个类的构造器中使用了"super(形参列表)",调用父类中的构造器。
代码演示:
public class Person { private String name; private int age; private Date birthDate; public Person(String name, int age, Date d) { this.name = name; this.age = age; this.birthDate = d; } public Person(String name, int age) { this(name, age, null); } public Person(String name, Date d) { this(name, 30, d); } public Person(String name) { this(name, 30); } }public class Student extends Person { private String school; public Student(String name, int age, String s) { super(name, age); school = s; } public Student(String name, String s) { super(name); school = s; }// 编译出错: no super(),系统将调用父类无参数的构造器。 public Student(String s) { school = s; } }
No. | 区别点 | this | super |
---|---|---|---|
1 | 访问属性 | 访问本类中的属性,如果本类没有此属性则从父类中继续查找 | 直接访问父类中的属性 |
2 | 调用方法 | 访问本类中的方法,如果本类没有此方法则从父类中继续查找 | 直接访问父类中的方法 |
3 | 调用构造器 | 调用本类构造器,必须放在构造器的首行 | 调用父类构造器,必须放在子类构造器的首行 |
(1)从结果上来看:(继承性)
子类继承父类以后,就获取了父类中声明的属性或方法。
创建子类的对象,在堆空间中,就会加载所有父类中声明的属性。
(2)从过程上来看:
当我们通过子类的构造器创建子类对象时,我们一定会直接或间接的调用其父类的构造器,进而调用父类的父类的构造器,…直到调用了java.lang.Object
类中空参的构造器为止。正因为加载过所有的父类的结构,所以才可以看到内存中有父类中的结构,子类对象才可以考虑进行调用。
(3)明确:虽然创建子类对象时,调用了父类的构造器,但是自始至终就创建过一个对象,即为
new
的子类对象。
推荐学习:《java视频教程》
以上がJavaのthisキーワードとsuperキーワードの詳細な分析の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。