import java.awt.*;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
public class MyFrame extends Frame{
MyFrame(String s){
super(s);//调用父类构造方法
}
public static void main(String[] args) {
MyFrame f = new MyFrame("窗口");//构造方法调用
f.setSize(200, 400);//设置窗口大小,默认为0,所以必须要设置
f.setVisible(true);//设置窗口可见,默认为不可见,所以必须要设置
f.addWindowListener(f.new Mywindowadapter());//为窗口添加监听器
}
class Mywindowadapter extends WindowAdapter{//实现窗口的关闭功能
public void windowClosing(WindowEvent we){//覆盖WindowAdapter方法
System.exit(0);//程序退出
}
}
}
依样画葫芦,想写一个顺序,结果报错了
少侠解答说是多个”f.”,内部类在类的内部可以直接使用。
再改,去掉”f.”,结果编译时出现:
No enclosing instance of type E is accessible. Must qualify the allocation with an enclosing instance of type E(e.g. x.new A() where x is an instance of E). E指代我写的那个内部类。
根据提示,没有可访问的内部类E的实例,必须分配一个合适的内部类E的实例(如x.new A(),x必须是E的实例。)看着这句提示,我就纳闷了,我已经用new实例化了这个类,为什么还不行呢。
原来我写的内部类是动态的,也就是开头以public class开头。而主程序是public static class main。在Java中,类中的静态方法不能直接调用动态方法。只有将某个内部类修饰为静态类,然后才能够在静态类中调用该类的成员变量与成员方法。所以在不做其他变动的情况下,最简单的解决办法是将public class改为public static class.
java中的内部类总结 - Nerxious - 博客园 http://www.cnblogs.com/nerxious/archive/2013/01/24/2875649.html