日期:2014-05-20  浏览次数:20678 次

问个关于内部类的问题
内部类在被实例化后就会自己执行类里面的方法而不用去调用吗?
比如:

class MyTimerTask extends TimerTask{
  public void run()//内部类的 run()方法
  {
  System.out.print("hello");
  new Timer().schedule(new MyTimerTask(),2000);
  }
}
 
new Timer().schedule(new MyTimerTask(),2000);//实例化了MyTimerTask对象

在上面的例子中,Timer在调用schedule()方法时,传入了一个MyTimerTask的对象,只是传入了对象,为什么就直接执行了其中的run()方法呢?请高手指教~!

------解决方案--------------------
内部类的方法一般来说也是需要调用的,但是 我们在应用各种设计模式的时候,会设计好一些固定的等待外部类状态变化后 执行内部类的变化,其实之所以这样,本质还是因为外部类调用了内部类的方法,只是编程者没有看到实现的代码细节

典型的就是SWING里面的ActionListener的ActionPerform方法,上面的这个run方法其实也是Timer的schedule方法自动调用的,这是Timer类已经写好的,但是不代表 内部类的一般情况
------解决方案--------------------
方法中的入口参数是一个局部变量

比如上面方法中的 参数名为timeTask 类型为TimeTask

你的 新建的对象(它暂时还没有引用指向它,但它不会立刻被垃圾回收器回收)

因为这个新建对象 传递给 局部变量timeTime(这里的局部变量也是一个引用,只能指向TimeTask型的对象)

此时 引用(局部变量)timeTime 指向了 那个对象 

这个局部变量的作用域是整个方法schedule都有效

里边的方法是如何实现的呢,只有sun公司内的那帮家伙才知道。

但我们可以肯定的是:里面的方法通过引用timeTime(还在作用域范围)直接或间接的启动了线程,





------解决方案--------------------
探讨

内部类的方法一般来说也是需要调用的,但是 我们在应用各种设计模式的时候,会设计好一些固定的等待外部类状态变化后 执行内部类的变化,其实之所以这样,本质还是因为外部类调用了内部类的方法,只是编程者没有看到实现的代码细节

典型的就是SWING里面的ActionListener的ActionPerform方法,上面的这个run方法其实也是Timer的schedule方法自动调用的,这是Timer……

------解决方案--------------------
public void schedule(TimerTask task,
long delay)安排在指定延迟后执行指定的任务。 

参数:
task - 所要安排的任务。
delay - 执行任务前的延迟时间,单位是毫秒。 

其中的任务是在这个机制中,由底层的java程序完成调用的,规则中规定默认调用的就是public void run()方法,java中这种机制在其它地方也有,比如线程中,默认执行的也是public void run()方法
------解决方案--------------------
看看源码, new Timer().schedule()里面是不是实现了调用呢?肯定调用了,只是被隐藏了罢了。