Java内部クラスのGUI設計における役割を浅く分析する(2)
32704 ワード
四、方法内部クラス
メソッド内部クラスは、メソッド内でのみ表示され、メソッド内部クラスはメソッド内の任意の場所を定義できます.
実行結果:
say foo!
say bar!
Process finished with exit code 0
五、匿名類
匿名クラスはクラス名を与えず、クラスを直接定義し、通常、このクラスは何らかのインタフェースまたは抽象を実現します.匿名クラスのアクセス権は議論の価値がありません.例を見ればいいです.
いくつかのマルチスレッドプログラムではよく見られますが、少し変態で、ほほほ.
実行結果:
say foo!
実行結果:
Fk{x='fk'}
Process finished with exit code 0
もう一つの古典的な例はthining in javaから来て、変更があります.
この応用は私たちに多くの思考を与えて、私は言わないで、異なる人が見て異なる感じがします.
内部類の巧みな使用はあなたのコードをとても牛にすることができて、もし形容するならば、それは:理解していない時に神が幽霊を出したと感じて、理解してから鬼斧神工を感じます.しかし、これらのコードが多くなって、他の人が理解したいのは難しいです.あなたの考えを理解したいのは難しいです.ほほほ!
六、静的内部クラス
静的内部クラスはstatic class型の内部クラスで、外部クラスの非静的メンバーにアクセスできないことを特徴としています.静的内部クラスオブジェクトを作成する場合は、外部クラスオブジェクトも必要ありません.
新外部クラス名内部クラス構築方法
で行ないます.
実行結果:
Hello 1111
501
Hello 2222
502
Process finished with exit code 0
七、インタフェース内部クラス
インタフェースの内部クラスは自動的にpublic staticであり、インタフェースに変数タイプを定義することに相当します.これはjavaの設計で使用されています.例えば、HashMapでは、次のようなものがあります.
static class Entry implements Map.Entry
次に例を示します
八、内部のクラスのネスト
内部クラスネストとは,内部クラスに内部クラスを再定義することである.実はこの使い方は見たことがないので、簡単な例を書いてみましょう.
実行結果:
f0
a
b
Process finished with exit code 0
八、内部クラスの継承
内部クラスの継承は、内部クラスを継承することも、外部クラスを継承することもできます.
実行結果:
Inner doing ...
Inner2 doing ...
HeHe!
Process finished with exit code 0
まとめ:
内部クラスはJavaの中で最も複雑で奥深い概念の一つであり、内部クラスはアクセス制御、修飾子、継承、実現、抽象、シーケンス化など多くの面で迷っている問題であり、実際には、これらの問題は永遠に明らかにする機会がないかもしれないが、一般的には、以上の内部クラスの知識を知っていれば十分だ.
内部クラスのデザインはJava言語そのものの先天的な不足を補うのかもしれませんが、言語としては、この特性が変態すぎる点は、他に方法がないのではないでしょうか.
以上の総括は完全に実践の基礎の上で創立して、列挙した例は偏っているかもしれなくて、全面的に問題の本質を反映することができなくて、興味のある博友がもっと自分の見方と観点を発表することを望みます.
この文書はhttp://developer.51cto.com/art/201002/183375_1.htm
必要な友达に役に立つことを望んでいます.
メソッド内部クラスは、メソッド内でのみ表示され、メソッド内部クラスはメソッド内の任意の場所を定義できます.
- /**
- *
- *
- * @author leizhimin 2009-7-17 14:57:50
- */
- public class Test2 {
- public static void main(String[] args) {
- Outer outer = new Outer();
- Foo f = outer.genFoo();
- Bar b = outer.genBar();
- f.say();
- b.readme();
- }
- }
-
- class Outer {
- public Foo genFoo() {
- //
- class FooImpl implements Foo {
- public void say() {
- System.out.println( "say foo!" );
- }
- }
- return new FooImpl();
- }
-
- public Bar genBar() {
- Bar b = null ;
- if ( true ) {
- //
- class BarImpl implements Bar {
- public void readme() {
- System.out.println( "say bar!" );
- }
- }
- b = new BarImpl();
- }
- return b;
- }
- }
実行結果:
say foo!
say bar!
Process finished with exit code 0
五、匿名類
匿名クラスはクラス名を与えず、クラスを直接定義し、通常、このクラスは何らかのインタフェースまたは抽象を実現します.匿名クラスのアクセス権は議論の価値がありません.例を見ればいいです.
いくつかのマルチスレッドプログラムではよく見られますが、少し変態で、ほほほ.
- /**
- * .
- *
- * @author leizhimin 2009-7-17 15:56:17
- */
- public class Test3 {
- public Foo f = new Foo() {
- public void say() {
- System.out.println( "O(∩_∩)O ~!" );
- }
- };
-
- public Foo test() {
- return new Foo() {
- public void say() {
- System.out.println( "say foo!" );
- }
- };
- }
-
- public static void main(String[] args) {
- Test3 t = new Test3();
- t.f.say();
- t.test().say();
- }
- }
-
- interface Foo {
- void say();
- }
実行結果:
say foo!
- Process finished with exit code 0
-
- /**
- *
- *
- * @author leizhimin 2009-7-17 16:13:31
- */
- public class Fk {
- private String x;
-
- public Fk(String x) {
- this .x = x;
- }
-
- @Override
- public String toString() {
- return "Fk{" +
- "x='" + x + '/ '' +
- '}' ;
- }
- }
-
- class Test4 {
- public Fk hehe() {
- // ,
- return new Fk( "fk" ) {
- };
- }
-
- public static void main(String[] args) {
- Test4 t = new Test4();
- Fk f = t.hehe();
- System.out.println(f);
- }
- }
実行結果:
Fk{x='fk'}
Process finished with exit code 0
もう一つの古典的な例はthining in javaから来て、変更があります.
- interface Service {
- void method1();
- void method2();
- }
-
- interface ServiceFactory {
- Service getService();
- }
-
- class Implementation1 implements Service {
- private Implementation1() {}
- public void method1() {System.out.println( "Implementation1 method1" );}
- public void method2() {System.out.println( "Implementation1 method2" );}
- public static ServiceFactory factory = new ServiceFactory() {
- public Service getService() {
- return new Implementation1();
- }
- };
- }
-
- class Implementation2 implements Service {
- private Implementation2() {}
- public void method1() {System.out.println( "Implementation2 method1" );}
- public void method2() {System.out.println( "Implementation2 method2" );}
- public static ServiceFactory factory = new ServiceFactory() {
- public Service getService() {
- return new Implementation2();
- }
- };
- }
-
- public class Factories {
- public static void serviceConsumer(ServiceFactory fact) {
- Service s = fact.getService();
- s.method1();
- s.method2();
- }
- public static void main(String[] args) {
- serviceConsumer(Implementation1.factory);
- serviceConsumer(Implementation2.factory);
- }
- }
この応用は私たちに多くの思考を与えて、私は言わないで、異なる人が見て異なる感じがします.
内部類の巧みな使用はあなたのコードをとても牛にすることができて、もし形容するならば、それは:理解していない時に神が幽霊を出したと感じて、理解してから鬼斧神工を感じます.しかし、これらのコードが多くなって、他の人が理解したいのは難しいです.あなたの考えを理解したいのは難しいです.ほほほ!
六、静的内部クラス
静的内部クラスはstatic class型の内部クラスで、外部クラスの非静的メンバーにアクセスできないことを特徴としています.静的内部クラスオブジェクトを作成する場合は、外部クラスオブジェクトも必要ありません.
新外部クラス名内部クラス構築方法
で行ないます.
- /**
- *
- *
- * @author leizhimin 2009-7-17 16:53:05
- */
- public class Outer {
- public static int i = 500 ;
- protected static class Inner {
- int i = 100 ;
- String name;
-
- Inner(String name) {
- this .name = name;
- }
-
- void sayHello() {
- System.out.println( "Hello " + name);
- Outer.i++;
- }
- }
-
- public Inner genInner(String name) {
- return new Inner(name);
- }
- }
-
- class Test {
- public static void main(String[] args) {
- Outer.Inner in1 = new Outer.Inner( "1111" );
- in1.sayHello();
- System.out.println(Outer.i);
-
- Outer.Inner in2 = new Outer().genInner( "2222" );
- in2.sayHello();
- System.out.println(Outer.i);
- }
- }
実行結果:
Hello 1111
501
Hello 2222
502
Process finished with exit code 0
七、インタフェース内部クラス
インタフェースの内部クラスは自動的にpublic staticであり、インタフェースに変数タイプを定義することに相当します.これはjavaの設計で使用されています.例えば、HashMapでは、次のようなものがあります.
static class Entry
次に例を示します
- /**
- *
- *
- * @author leizhimin 2009-7-17 17:20:28
- */
- public interface AInterface {
- void readme();
-
- class Inner1 implements AInterface {
- public void readme() {
- System.out.println( " " );
- }
- }
- }
-
- class Main {
- public static void main(String[] args) {
- AInterface.Inner1 in1 = new AInterface.Inner1();
- in1.readme();
- }
- }
八、内部のクラスのネスト
内部クラスネストとは,内部クラスに内部クラスを再定義することである.実はこの使い方は見たことがないので、簡単な例を書いてみましょう.
- /**
- *
- *
- * @author leizhimin 2009-7-17 17:33:48
- */
- public class Outer {
- private void f0() {
- System.out.println( "f0" );
- }
-
- class A {
- private void a() {
- f0();
- System.out.println( "a" );
- }
-
- class B {
- protected void b() {
- a();
- System.out.println( "b" );
- }
- }
- }
- }
- class Test{
- public static void main(String[] args) {
- Outer o = new Outer();
- Outer.A a = o. new A();
- Outer.A.B b = a. new B();
- b.b();
- }
- }
実行結果:
f0
a
b
Process finished with exit code 0
八、内部クラスの継承
内部クラスの継承は、内部クラスを継承することも、外部クラスを継承することもできます.
- /**
- * , ,
- *
- * @author leizhimin 2009-7-22 13:50:01
- */
- public class Outer {
- class Inner {
- void doSomething() {
- System.out.println( "Inner doing ..." );
- }
- }
-
- class Inner2 extends Inner {
- void doSomething() {
- System.out.println( "Inner2 doing ..." );
- }
-
- void readme() {
- System.out.println( "HeHe!" );
- }
- }
- }
-
- class Test {
- public static void main(String[] args) {
- Outer outer = new Outer();
- Outer.Inner in = outer. new Inner();
- Outer.Inner2 in2 = outer. new Inner2();
- in.doSomething();
- in2.doSomething();
- in2.readme();
- }
- }
実行結果:
Inner doing ...
Inner2 doing ...
HeHe!
Process finished with exit code 0
まとめ:
内部クラスはJavaの中で最も複雑で奥深い概念の一つであり、内部クラスはアクセス制御、修飾子、継承、実現、抽象、シーケンス化など多くの面で迷っている問題であり、実際には、これらの問題は永遠に明らかにする機会がないかもしれないが、一般的には、以上の内部クラスの知識を知っていれば十分だ.
内部クラスのデザインはJava言語そのものの先天的な不足を補うのかもしれませんが、言語としては、この特性が変態すぎる点は、他に方法がないのではないでしょうか.
以上の総括は完全に実践の基礎の上で創立して、列挙した例は偏っているかもしれなくて、全面的に問題の本質を反映することができなくて、興味のある博友がもっと自分の見方と観点を発表することを望みます.
この文書はhttp://developer.51cto.com/art/201002/183375_1.htm
必要な友达に役に立つことを望んでいます.