为什么Java Enums比Interfaces使用更多内存?

时间:2016-07-27 14:40:38

标签: java javacompiler

我测试了类,枚举,接口这三种方法来封装常量String。

   public class Company {
        public final static String CAPITAL_ONE = "Capital_One";
    }
    public interface ICompany {
        public final static String CAPITAL_ONE = "Capital_One";
    }
    public enum ECompany {
        CAPITAL_ONE
    }

编译后,它们生成了330个字节,181个字节和818个字节的字节码,这意味着当加载到jvm中时,接口ICompany将花费更少的内存。这是为什么?

2 个答案:

答案 0 :(得分:3)

使用javap实用程序检查3“.class”文件并比较输出。例如:

$ javap -c Company.class 

简短的回答是values()类必须实现一些标准方法(valueOf(String)toString()enum),但其他类不必须。

话虽如此,“。class”文件的大小不一定是加载类和JIT编译时使用的内存的准确预测器。

答案 1 :(得分:0)

单个类文件定义类或接口。查看结构(https://docs.oracle.com/javase/specs/jvms/se7/html/jvms-4.html):

    ClassFile {
    u4             magic;
    u2             minor_version;
    u2             major_version;
    u2             constant_pool_count;
    cp_info        constant_pool[constant_pool_count-1];
    u2             access_flags;
    u2             this_class;
    u2             super_class;
    u2             interfaces_count;
    u2             interfaces[interfaces_count];
    u2             fields_count;
    field_info     fields[fields_count];
    u2             methods_count;
    method_info    methods[methods_count];
    u2             attributes_count;
    attribute_info attributes[attributes_count];
    }

Enum是一个类,如果你看它编译的内容,你可以看到为什么有必要的开销(见这里:In java, What does such enum type compile to?)。接口是一种抽象类型,它实际上只是一个类必须符合的一组操作和常量。

ICompany.class:

����4   
CAPITAL_ONELjava/lang/String;
ConstantValue
SourceFile
ICompany.javaICompanyjava/lang/ObjectCapital_One

ECompany.class:

����4(  


!

"
"   #$CAPITAL_ONE
LECompany;$VALUES[LECompany;values
()[LECompany;CodeLineNumberTablevalueOf(Ljava/lang/String;)LECompany;<init>(Ljava/lang/String;I)V   Signature()V<clinit>Ljava/lang/Enum<LECompany;>;
SourceFile
ECompany.java
%&ECompany'java/lang/Enumclone()Ljava/lang/Object;5(Ljava/lang/Class;Ljava/lang/String;)Ljava/lang/Enum;@1
@
    "
����    "
*���*+��7�Y��   �Y� S��

从类文件中,您可以看到示例中的接口在方法或标志方面没有太多添加,因此尺寸较小。