Java的注解功能能够为我们节省很多源代码,其实就是用机器来批量处理事情了,那注解的工作原理是什么样的呢?其实使用了注解,肯定要有解析注解的代码,解析注解又可以分为两种,一种是运行时通过反射解析处理,一种是通过定义注解处理器编译生成新的文件,区别就是前者运行效率较后者差,前者使用较后者方便,所以不同技术手段往往具有相反的特性,可以满足不同环境下的需求。

这里我们讨论下运行时注解的情况,我们知道注解可以作用于类、方法、域、方法参数等,运行时,会有程序去扫描这些注解,当然扫描的技术手段就是反射机制。大致看来好像很好理解,有些细节需要我们深究,这里以Spring为例,当我们使用@Autowired注解时,没有给数据成员赋值,那运行时是如何处理的呢?其实就是反射,因为反射不仅可以拿到类型的元信息,还可以通过这些元信息对实例进行操作,下面的例子看了就明白了,下面的例子中,我们通过反射对实例进行了域的赋值:

public class AutowiredT {
    public static void main(String[] args) throws Exception {
        TT o = new TT();
        Class c = o.getClass();
        Field f = c.getDeclaredField("a");
        f.setAccessible(true);
        f.set(o, 4);
        System.out.println(o.a);
    }
}

class TT {
    public int a;
}

 

Logo

瓜分20万奖金 获得内推名额 丰厚实物奖励 易参与易上手

更多推荐