java文件编译后额外生成的$1.class是怎么一回事_java文件编译后额外生成的$1.class是怎么一回事...

首先java文件编译生成class文件其基本规则是这样的:

内部类的class文件命名是:主类+$+内部类名

匿名类的class文件命名是:主类+$+(1,2,3....)

但是如果没有使用匿名类,会生成带$1.class文件么~~答案是会的。

先来看这样一段代码~

public class TestJavac

{

void Test()

{

innerClass lklk = new innerClass();

lklk.biubiu();

}

private class innerClass

{

private innerClass()

{

// TODO 自动生成的构造函数存根

}

void biubiu()

{

System.out.println("XXXX");

}

}

}

此java文件经过javac编译后(注意是手动使用javac编译或者使用ant编译)应该生成几个class文件呢?

TestJavac.class

TestJavac$innerClass.class

这两个你肯定知道,但是还会生成一个TestJavac$1.class

这玩意儿是怎么来的?

将其反编译内容为~~空的

class TestJavac$1

{

}

但是eclipse编译后就没有TestJavac$1.class这个文件,这究竟是嘛回事儿呢?

当内部类是私有的且没有明确书写公有的构造函数时,那么缺省构造函数就是私有的,javac对这种情况的处理就是创建一个可以访问的带有一个参数的构造函数,而这个参数的类型是一个匿名的静态类,所以编译时就会多生成一个匿名类的class文件,所以生成了XXX$1.class文件。

有人说JDK1.4才会有这种情况,但我的javac版本是1.6.0_21,也会有此问题。

Eclipse JDT使用的编译器与JDK提供的javac是不一样的,EclipseJDT使用的是它自己内建的编译器ecj(theEclipse Compiler for Java)或者说JDT Core Batch Compiler也行。有一些增强的功能,包括对上述情况的完美处理(不会凭空给你增加一个匿名类)。

想规避这种情况很简单:

1、内部类设为公有。

2、明确的书写内部类的构造函数并设置其可见性为public。

3

、使用其它的

java

编译器如

JDT

里的

ecj

对于如何在ANT中使用JDT的java编译器可以参考这篇文章

http://3426915.blog.51cto.com/3416915/640482

个人感觉:不是SUN的javac太差了,而是IBM的eclipse太强了~~

表情包
插入表情
评论将由博主筛选后显示,对所有人可见 | 还能输入1000个字符
©️2020 CSDN 皮肤主题: 游动-白 设计师:白松林 返回首页