コンパイル時のポリモーフィズムと実行時のポリモーフィズムの違い
ポリモーフィズムは、最も重要なOOPの概念の1つです。これは、単一のタスクを複数の方法で実行できるという概念です。ポリモーフィズムには、コンパイル時のポリモーフィズムと実行時のポリモーフィズムの2種類があります。
メソッドのオーバーロードはコンパイル時のポリモーフィズムの例であり、メソッドのオーバーライドは実行時のポリモーフィズムの例です。
| Sr。いいえ。 | キー | コンパイル時のポリモーフィズム | ランタイムポリモーフィズム |
|---|---|---|---|
| 1 | 基本 | コンパイル時のポリモーフィズムは、コンパイル時にバインディングが発生していることを意味します | R un time polymorphism実行時に、どのメソッドが呼び出されるかを知るようになりました |
| 2 | 静的/動的 バインディング | 静的バインディングによって実現できます | 動的バインディングによって実現できます |
| 4。 | 継承 | 継承は関係ありません | 継承が含まれます |
| 5 | 例 | メソッドのオーバーロードは、コンパイル時のポリモーフィズムの例です | メソッドのオーバーライドは、実行時のポリモーフィズムの例です |
コンパイル時のポリモーフィズムの例
public class Main {
public static void main(String args[]) {
CompileTimePloymorphismExample obj = new CompileTimePloymorphismExample();
obj.display();
obj.display("Polymorphism");
}
}
class CompileTimePloymorphismExample {
void display() {
System.out.println("In Display without parameter");
}
void display(String value) {
System.out.println("In Display with parameter" + value);
}
} ランタイムポリモーフィズムの例
public class Main {
public static void main(String args[]) {
RunTimePolymorphismParentClassExample obj = new RunTimePolymorphismSubClassExample();
obj.display();
}
}
class RunTimePolymorphismParentClassExample {
public void display() {
System.out.println("Overridden Method");
}
}
public class RunTimePolymorphismSubClassExample extends RunTimePolymorphismParentExample {
public void display() {
System.out.println("Overriding Method");
}
} -
Javaでのイテレータと列挙の違い
IteratorとEnumerationはどちらも、コレクションの要素をトラバースしてアクセスするためのカーソルです。どちらもコレクションフレームワークに属しています。列挙は、コレクションフレームワークのJDK1.2バージョンのJDK1.0およびIteratorで追加されました。 コレクション内の要素への読み取り専用アクセス権があるため、列挙型はコレクション内の構造を変更できません。次の方法があります: * hasMoreElements() * nextElement() 一方、イテレータはコレクション内の要素を読み取って削除できます。以下の方法があります- * hasNe
-
JavaでのArrayListとHashSetの違い
HashSetとArrayListはどちらも、Javaコレクションフレームワークの最も重要なクラスの一部です。 以下は、ArrayListとHashSetの重要な違いです。 Sr。いいえ。 キー ArrayList ハッシュセット 1 実装 ArrayListはリストインターフェイスの実装です。 一方、 HashSetは、セットインターフェイスの実装です。 2 内部実装 ArrayListは、その実装のために配列を内部的に実装します。 HashSetは、実装にHashmapを内部的に使用します。 3 要素の順序 ArrayListは、挿入順序、つまり