別のクラスを拡張するクラス、別のクラスを拡張するクラスなどがあります。
100レベルの階層レベルのクラスがどのくらい遅く(パーセントで)機能し、次に10レベルの階層レベルのクラスが機能しますか?
別のクラスを拡張するクラス、別のクラスを拡張するクラスなどがあります。
100レベルの階層レベルのクラスがどのくらい遅く(パーセントで)機能し、次に10レベルの階層レベルのクラスが機能しますか?
試してみましょう:
class T1 {}
class T2 extends T1{}
class T3 extends T2{}
class T4 extends T3{}
class T5 extends T4{}
class T6 extends T5{}
class T7 extends T6{}
class T8 extends T7{}
class T9 extends T8{}
class T10 extends T9{}
class T11 extends T10{}
class T12 extends T11{}
class T13 extends T12{}
class T14 extends T13{}
class T15 extends T14{}
class T16 extends T15{}
class T17 extends T16{}
class T18 extends T17{}
class T19 extends T18{}
class T20 extends T19{}
class T21 extends T20{}
class T22 extends T21{}
class T23 extends T22{}
class T24 extends T23{}
class T25 extends T24{}
class T26 extends T25{}
class T27 extends T26{}
class T28 extends T27{}
class T29 extends T28{}
class T30 extends T29{}
class T31 extends T30{}
class T32 extends T31{}
class T33 extends T32{}
class T34 extends T33{}
class T35 extends T34{}
class T36 extends T35{}
class T37 extends T36{}
class T38 extends T37{}
class T39 extends T38{}
class T40 extends T39{}
class T41 extends T40{}
class T42 extends T41{}
class T43 extends T42{}
class T44 extends T43{}
class T45 extends T44{}
class T46 extends T45{}
class T47 extends T46{}
class T48 extends T47{}
class T49 extends T48{}
class T50 extends T49{}
class T51 extends T50{}
class T52 extends T51{}
class T53 extends T52{}
class T54 extends T53{}
class T55 extends T54{}
class T56 extends T55{}
class T57 extends T56{}
class T58 extends T57{}
class T59 extends T58{}
class T60 extends T59{}
T53をインスタンス化できましたが、T54以降はStackOverflowErrorをスローしました。
new T54();
Exception in thread "main" java.lang.StackOverflowError
at java.lang.ref.Reference.<init>(Reference.java:216)
at java.lang.ref.FinalReference.<init>(FinalReference.java:16)
at java.lang.ref.Finalizer.<init>(Finalizer.java:66)
at java.lang.ref.Finalizer.register(Finalizer.java:72)
at java.lang.Object.<init>(Object.java:20)
at java.io.InputStream.<init>(InputStream.java:28)
at java.io.FileInputStream.<init>(FileInputStream.java:96)
at sun.misc.URLClassPath$FileLoader$1.getInputStream(URLClassPath.java:1005)
at sun.misc.Resource.cachedInputStream(Resource.java:61)
at sun.misc.Resource.getByteBuffer(Resource.java:144)
at java.net.URLClassLoader.defineClass(URLClassLoader.java:256)
at java.net.URLClassLoader.access$000(URLClassLoader.java:58)
at java.net.URLClassLoader$1.run(URLClassLoader.java:197)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
at java.lang.ClassLoader.loadClass(ClassLoader.java:307)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
at java.lang.ClassLoader.loadClass(ClassLoader.java:248)
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClassCond(ClassLoader.java:632)
at java.lang.ClassLoader.defineClass(ClassLoader.java:616)
at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:141)
at java.net.URLClassLoader.defineClass(URLClassLoader.java:283)
at java.net.URLClassLoader.access$000(URLClassLoader.java:58)
at java.net.URLClassLoader$1.run(URLClassLoader.java:197)
at java.security.AccessController.doPrivileged(Native Method)
at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
at java.lang.ClassLoader.loadClass(ClassLoader.java:307)
at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
at java.lang.ClassLoader.loadClass(ClassLoader.java:248)
これは、デフォルトのJVMスタックサイズを使用して行われました。
100レベルの階層の場合、より大きなスタックが必要になります。(を使用してスタックサイズを増やすことができますXss
。)
「優れたJVM」(それが意味するものは何でも)は、メソッド解決の結果をキャッシュします。したがって、パフォーマンスへの影響は1回だけ発生するはずであり、それでも最小限に抑えられる可能性があります。ただし、オブジェクトの作成時に、すべての拡張クラスのインスタンスも作成され、すべてのスーパークラスのすべてのコンストラクターが呼び出されます。これにより、大きな階層を持つ多数のオブジェクトを作成するときに大きな影響が生じる可能性があります。
いくつかの深刻な設計上の問題があるか、コードジェネレーターが不正になっているように聞こえるという点で、私はJon Skeet(まあ、そうではありません)に同意する必要があります。これは、「データベーステーブルがサポートする列の数」を尋ねるのと似ています。それが合理的以上である場合、あなたはおそらくそれを間違っているのです。
これは、JVM、実行している正確な操作、さまざまなメソッドがオーバーライドされているかどうかなどによって異なります。
ただし、パフォーマンスへの影響よりも、デザインと読みやすさへの影響の方がはるかに心配です。これは本当にあなたが思いつくことができる最高のデザインですか?別の方法でよりよく解決することができなかったそれはどのような問題を解決しますか?
Java2の完全なリファレンス作成者であるHerbertSchildrによると:
ただし、どのクラスも継承できません。5を超えるJavaクラス継承のレベルはそれほど高くありません。これにより、常にパフォーマンスが低下します。
ジョン・スキートの答えにも同意します。