I.はじめに
三つの特徴の一つで言えば、このマルチステートは、人気の理解、様々な形態、ジェスチャーの様々な行かなければならないことがあります。
だから、オブジェクト指向プログラミングでは、多型は何を指し?
「多型」(多型)が「何を」と「どのように」二つのモジュールの分離を達成するために、すなわち、特定の実装の詳細、アウト別の角度からインターフェースから分離されます。多型の概念を使用して、コードおよび組織の可読性を向上させることができます。また、それはまた、プログラムを「拡張が容易」を作成することができます。プロジェクトを作成する、または新しい機能を追加する必要があるとき、彼らは簡単にできるの過程で両方とも「成長します。」--ThinkinJava
網易直接百科事典-Polymorphism
第二に、条件が発生
- 継承。サブクラスとスーパークラスの間で多型でなければなりません。
- カバレッジ。メソッドのサブクラスはスーパークラスを上書きします
- サブクラスに親クラスの変数の宣言が、実際にポイントを入力します。新しいプログラムは、後にサブクラスであります
//f4变量是子类类型,指向子类实例
Triangle f4 = new Triangle();
第三に、多型を含む(または、反射)は、2つの側面:
- 最初は、特定のメソッドに対して異なる効果を達成するために、同じ方法であり、それは異なる可能性があり、実現する方法です。これは、ある多型。
吃苹果方法,可以剥皮吃,也可以不剥皮吃,甚至是榨苹果汁喝。
この仕様は、オーバーロードとオーバーライドすることによって達成することができ話しています
- オーバーロード:同じメソッドの名前は、異なるタイプおよびパラメータの数ので、別の効果を達成することが可能です。
- オーバーライド:同じ方法で、異なるサブクラスオブジェクトの例、及び達成最終的な効果は、同一の機能ではありません。
-
多型のオブジェクト
親クラス参照のタイプ:参照型の変換は、括弧演算子、二方向にキャストすることにより実現されます
サブクラスタイプの変数は、この変換は、下方遷移(ダウンキャスト)と呼ばれる、サブクラス参照型の変数に
親クラスのタイプは、この変換は、上方遷移(アップキャスト)と呼ばれています。ダウンキャストが必要な、鋳造アップが自己であるキャスト
移動。
- 最大の移行:親クラスのサブクラスのオブジェクト
- 意気消沈:親オブジェクトは、サブクラスになり
第四に、例えば、
- 多型の単純な例では、コードは@Override擬似表現書き直し内にあります。一般的に、あなたは正しく書き直し、IDEが自動的にリストに追加されます。これは、認証方法です。
package music.daima.ebook;
class Figure{
//绘制几何图形方法
public void onDraw() {
System.out.println("绘制Figure...");
}
}
class Ellipse extends Figure{
@Override
public void onDraw() {
System.out.println("绘制椭圆形");
}
}
class Triangle extends Figure {
// 绘制几何图形方法
@Override
public void onDraw() {
System.out.println("绘制三角形...");
} }
public class PolymorphismEasy {
public static void main(String[] args) {
// f1变量是父类类型,指向父类实例
Figure f1 = new Figure();
f1.onDraw();
//f2变量是父类类型,指向子类实例,发生多态
Figure f2 = new Triangle();
f2.onDraw();
//f3变量是父类类型,指向子类实例,发生多态
Figure f3 = new Ellipse();
f3.onDraw();
//f4变量是子类类型,指向子类实例
Triangle f4 = new Triangle( );
f4.onDraw();
}
}
//output:
绘制Figure...
绘制三角形...
绘制椭圆形
绘制三角形...
- あなたはプライベートメソッドをオーバーライドすることはできません
package music.daima.ebook;
public class PolymorphismFugai {
private void p(){//if public...就可以覆盖
System.out.println("1");
}
public static void main(String[] args) {
PolymorphismFugai s = new jicheng();
s.p();//将输出的是上面的1而不是我们想要的jicheng类中的方法
}
}
class jicheng extends PolymorphismFugai{
public void p(){
System.out.println("2");
}
}
//output:1
- 静的メソッドと静的マルチ状態の関係
package music.daima.ebook;
//这一篇是用来研究静态方法与多态的
class A {
public static String get(){//定义一个方法
return "A is base";
}
}
//继承A
class B extends A {
public static String get(){//同样的方法
return "B is not base";
}
}
public class StaticUpcast {
public static void main(String[] args) {
A a = new B();//upcast 向上转型
System.out.println(a.get());
}
}
//output:
//A is base
//从这里发现静态方法是与类相关联的,不是与单个对象关联的,不能覆盖掉