Java 内部类相关

摘抄部分http://www.cnblogs.com/nerxious/archive/2013/01/25/2876489.html

实例化内部类:

创建内部类的实例对象
时,一定要先创建外部类的实例对象,然后用这个外部类的实例对象去创建内部类的实例对
象,代码如下:
Outer outer = new Outer();
Outer.Inner1 inner1 = outer.new Innner1();


内部类中不能定义静态成员(静态成员不是对象的特性)。
内部类可以定义在外部类的方法外面,也可以定义在外部类的方法体中


例程

package com.lixurui.test;

class Out {
private int age = 12;

class In {
private int age = 13;
public void print() {
int age = 14;
System.out.println("Local:" + age);
System.out.println("Innner:" + this.age);
System.out.println("Outer:" + Out.this.age);
}
}
}

public class FirstTest {
public static void main(String[] args) {
Out.In in = new Out().new In();
in.print();
}
}


有一个特殊的内部类,叫嵌套类。static Nested Class。

class Outer
{
static int x;
static class Inner
{
void test()
{
syso(x);
}
}
}

在这种情况下不可以访问外部类的普通成员变量,而只能访问外部类中的静态成员。



还有一种匿名内部类。它通常用来简化代码编写
使用匿名内部类还有个前提条件:必须继承一个父类或实现一个接口

实例1:不使用匿名内部类来实现抽象方法
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
abstract  class  Person {
     public  abstract  void  eat();
}
 
class  Child  extends  Person {
     public  void  eat() {
         System.out.println( "eat something" );
     }
}
 
public  class  Demo {
     public  static  void  main(String[] args) {
         Person p =  new  Child();
         p.eat();
     }
}

运行结果:eat something

可以看到,我们用Child继承了Person类,然后实现了Child的一个实例,将其向上转型为Person类的引用

但是,如果此处的Child类只使用一次,那么将其编写为独立的一个类岂不是很麻烦?

这个时候就引入了匿名内部类

 

实例2:匿名内部类的基本实现
1
2
3
4
5
6
7
8
9
10
11
12
13
14
abstract  class  Person {
     public  abstract  void  eat();
}
 
public  class  Demo {
     public  static  void  main(String[] args) {
         Person p =  new  Person() {
             public  void  eat() {
                 System.out.println( "eat something" );
             }
         };
         p.eat();
     }
}
 
实例3:在接口上使用匿名内部类
interface  Person {
     public  void  eat();
}
 
public  class  Demo {
     public  static  void  main(String[] args) {
         Person p = new  Person() {
             public  void  eat() {
                 System.out.println( "eat something" );
             }
         };
         p.eat();
     }
}

运行结果:eat something

 

由上面的例子可以看出,只要一个类是抽象的或是一个接口,那么其子类中的方法都可以使用匿名内部类来实现

最常用的情况就是在多线程的实现上,因为要实现多线程必须继承Thread类或是继承Runnable接口

 

实例5:Runnable接口的匿名内部类实现
public class FirstTest {
    
    
    public static void main(String[] args) {
       
        Runnable r = new Runnable() {

        Object obj = new Object();
            
          public void run() {
            synchronized(obj){
                for (int i = 1; i <= 5; i++) {
                    System.out.print(i + " ");
                }
            }
          }
        };
        Thread t1 = new Thread(r);
        Thread t2 = new Thread(r);
        t1.start();
        t2.start();
    }
}

正常的应该是下面这样:

 

package com.test.sleepwait;

public class MultiThread {
    private int j= 100;
 
    
    public static void main(String[] args){
            Thread t1=new Thread(new T1());
            Thread t2=new Thread(new T2());
            t1.start();
            t2.start();
          }
    }
    
  class T1 implements Runnable{
    public void run(){
      for(int i=0;i<15;i++)
        System.out.println("Runner A="+i);
    }
  }
  class T2 implements Runnable{
    public void run(){
      for(int j=0;j<15;j++)
        System.out.println("Runner B="+j);
    }
  }
   
用内部类应该如下:

package com.test.sleepwait;

public class MultiThread {
    private int j= 100;
    
    class Thread1 implements Runnable{
        @Override
         public void run(){
            synchronized(MultiThread.class){
               j++;
               System.out.println(Thread.currentThread().getName()+ "  " + j);
        }
        }
    }
     

    class Thread2 implements Runnable{
        @Override
         public void run(){
            synchronized(MultiThread.class){
               j--;
               System.out.println(Thread.currentThread().getName()+ "  " + j);
        }
        }
    }
    
    public static void main(String[] args){
        System.out.println(Thread.currentThread().getName());
        
        MultiThread tt=new MultiThread();

        for(int i=0;i<2;i++){
            Thread t1=new Thread(tt.new Thread1());  // 要想实例化内部类,要先实例化一个 主类,这里是MultiThread
            t1.start();
            Thread t2=new Thread(tt.new Thread2());
            t2.start();
            }
             
    }
    
}





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值