三つの状態と同じくらいのJavaの特性について話します

I.はじめに

三つの特徴の一つで言えば、このマルチステートは、人気の理解、様々な形態、ジェスチャーの様々な行かなければならないことがあります。

だから、オブジェクト指向プログラミングでは、多型は何を指し?

「多型」(多型)が「何を」と「どのように」二つのモジュールの分離を達成するために、すなわち、特定の実装の詳細、アウト別の角度からインターフェースから分離されます。多型の概念を使用して、コードおよび組織の可読性を向上させることができます。また、それはまた、プログラムを「拡張が容易」を作成することができます。プロジェクトを作成する、または新しい機能を追加する必要があるとき、彼らは簡単にできるの過程で両方とも「成長します。」--ThinkinJava

網易直接百科事典-Polymorphism

第二に、条件が発生

  • 継承。サブクラスとスーパークラスの間で多型でなければなりません。
  • カバレッジ。メソッドのサブクラスはスーパークラスを上書きします
  • サブクラスに親クラスの変数の宣言が、実際にポイントを入力します。新しいプログラムは、後にサブクラスであります
 //f4变量是子类类型,指向子类实例
        Triangle f4 = new Triangle();

第三に、多型を含む(または、反射)は、2つの側面:

  1. 最初は、特定のメソッドに対して異なる効果を達成するために、同じ方法であり、それは異なる可能性があり、実現する方法です。これは、ある多型
  吃苹果方法,可以剥皮吃,也可以不剥皮吃,甚至是榨苹果汁喝。

この仕様は、オーバーロードとオーバーライドすることによって達成することができ話しています

  • オーバーロード:同じメソッドの名前は、異なるタイプおよびパラメータの数ので、別の効果を達成することが可能です。
  • オーバーライド:同じ方法で、異なるサブクラスオブジェクトの例、及び達成最終的な効果は、同一の機能ではありません。
  1. 多型のオブジェクト

    親クラス参照のタイプ:参照型の変換は、括弧演算子、二方向にキャストすることにより実現されます

    サブクラスタイプの変数は、この変換は、下方遷移(ダウンキャスト)と呼ばれる、サブクラス参照型の変数に

    親クラスのタイプは、この変換は、上方遷移(アップキャスト)と呼ばれています。ダウンキャストが必要な、鋳造アップが自己であるキャスト

    移動。

    • 最大の移行:親クラスのサブクラスのオブジェクト
    • 意気消沈:親オブジェクトは、サブクラスになり

第四に、例えば、

  • 多型の単純な例では、コードは@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
//从这里发现静态方法是与类相关联的,不是与单个对象关联的,不能覆盖掉

読んでくれてありがとう

おすすめ

転載: www.linuxidc.com/Linux/2020-01/162015.htm