假设我有一个具体的类Class1,我正在用它创建一个匿名类。

Object a = new Class1(){
        void someNewMethod(){
        }
      };

现在有没有办法重载这个匿名类的构造函数。如下图所示

Object a = new Class1(){
        void someNewMethod(){
        }
        public XXXXXXXX(int a){
          super();
          System.out.println(a);
        }
      };

用xxxxxxxx来命名构造函数?


当前回答

这是不可能的,但是你可以像这样添加一个匿名初始化器:

final int anInt = ...;
Object a = new Class1()
{
  {
    System.out.println(anInt);
  }

  void someNewMethod() {
  }
};

不要忘记对匿名类使用的局部变量或参数的声明使用final,就像我对anInt所做的那样。

其他回答

是的,你不能在匿名类中定义构造函数,这是对的,但这并不意味着匿名类没有构造函数。迷惑…… 实际上,你不能在匿名类中定义construct,但是编译器为它生成了一个构造函数,该构造函数具有与其父构造函数相同的签名。如果父对象有多个构造函数,则匿名对象将有且只有一个构造函数

Java语言规范,第15.9.5.1节:

匿名类不能具有 显式声明的构造函数。

不好意思:(

编辑:作为一种替代方法,您可以创建一些最终局部变量,和/或在匿名类中包含实例初始化式。例如:

public class Test {
    public static void main(String[] args) throws Exception {
        final int fakeConstructorArg = 10;

        Object a = new Object() {
            {
                System.out.println("arg = " + fakeConstructorArg);
            }
        };
    }
}

虽然很难看,但也许能帮到你。或者,使用合适的嵌套类:)

这是不可能的,但是你可以像这样添加一个匿名初始化器:

final int anInt = ...;
Object a = new Class1()
{
  {
    System.out.println(anInt);
  }

  void someNewMethod() {
  }
};

不要忘记对匿名类使用的局部变量或参数的声明使用final,就像我对anInt所做的那样。

如果你不需要传递参数,那么初始化代码就足够了,但如果你需要从一个控制器传递参数,有一种方法可以解决大多数情况:

Boolean var= new anonymousClass(){
    private String myVar; //String for example

    @Overriden public Boolean method(int i){
          //use myVar and i
    }
    public String setVar(String var){myVar=var; return this;} //Returns self instane
}.setVar("Hello").method(3);

这里有另一种解决问题的方法:

public class Test{

    public static final void main(String...args){

        new Thread(){

            private String message = null;

            Thread initialise(String message){

                this.message = message;
                return this;
            }

            public void run(){
                System.out.println(message);
            }
        }.initialise(args[0]).start();
    }
}