昨天在写代码中,发现了一个有趣的现象
简单描述一下过程
- 初步定义了一个注解,其中一个
name()方法返回一个String类型; - 指定了其默认值为一个静态的对象
Test.name; - 通过
Main函数进行执行,发现这两个对象运行时,竟不是同一个对象; - JetBrain 的反编译功能查看,发现
Test.name被转换成了 ‘123’ 的常量值。
其实这里更好奇的是,Java String Constant Pool 为什么没有起作用;
目前怀疑点还是在内存分配的空间上:由于常量字符串池是在堆上分配,而注解是在非堆(这点不是很确认)?
下面是代码:
package com.example._17.demo.blog;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
import java.lang.reflect.Field;
public class Question {
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.FIELD)
@interface Test {
String name = "123";
String name() default name;
}
@Test
public final String demo = "123";
public static void main(String[] args) throws NoSuchFieldException, IllegalAccessException {
Field field = Question.class.getField("demo");
Test annotation = field.getAnnotation(Test.class);
System.out.println(annotation.name() == Test.name);
}
}