发表于: 2020-08-09 17:06:40
2 2317
- 今天完成的事情:完成部分深度思考,图片存储API调用,图片迁移
遇到的问题:
收获:
深度思考
1.什么是Annotation,怎么自定义Annotation,Annotation和XML的优缺点各是什么?
1.1 首先明白的是Annotation就是注解的意思,从JDK5开始Java开始对元数据进行支持,和注释是有区别的,可以理解为对代码的特殊标记,这些标记可以在编译,类加载,运行时被加载,并执行相应的处理,在不改变原有代码情况下对源代码的嵌入式补充,和javadoc不同。
javadoc是sun公司提供的技术,它从源代码中提取类,方法,成员等注释形成的一个和源代码配套的API帮助文档。
1.2 然后就是有哪些注解喃
java定义了7个,3个在java.lang包中(@Override.@Deprecated.@SuppressWarnings),剩下的4个在java.lang.annotation中
作用在代码的注解是
- @Override - 检查该方法是否是重写方法。如果发现其父类,或者是引用的接口中并没有该方法时,会报编译错误。
- @Deprecated - 标记过时方法。如果使用该方法,会报编译警告。
- @SuppressWarnings - 指示编译器去忽略注解中声明的警告。
作用在其他注解的注解(或者说 元注解)是:
- @Retention - 标识这个注解怎么保存,是只在代码中,还是编入class文件中,或者是在运行时可以通过反射访问。
- @Documented - 标记这些注解是否包含在用户文档中。
- @Target - 标记这个注解应该是哪种 Java 成员。
- @Inherited - 标记这个注解是继承于哪个注解类(默认 注解并没有继承于任何子类)
从 Java 7 开始,额外添加了 3 个注解:
- @SafeVarargs - Java 7 开始支持,忽略任何使用参数为泛型变量的方法或构造函数调用产生的警告。
- @FunctionalInterface - Java 8 开始支持,标识一个匿名函数或函数式接口。
- @Repeatable - Java 8 开始支持,标识某注解可以在同一个声明上使用多次。
(01) 1 个 Annotation 和 1 个 RetentionPolicy 关联。
可以理解为:每1个Annotation对象,都会有唯一的RetentionPolicy属性。
(02) 1 个 Annotation 和 1~n 个 ElementType 关联。
可以理解为:对于每 1 个 Annotation 对象,可以有若干个 ElementType 属性。
(03) Annotation 有许多实现类,包括:Deprecated, Documented, Inherited, Override 等等。
Annotation 的每一个实现类,都 "和 1 个 RetentionPolicy 关联" 并且 " 和 1~n 个 ElementType 关联"。
1.3 自定义注解
定义一个Annotation接口,最基本需要关联两个属性,ElementType(Annotation作为某种用途,比如修饰方法上,METHOD)和RetentionPolicy(指定 Annotation 的策略,就是作用范围,SOURCE,CLASS,RUNTIME三种取值) 是两个Enum枚举类型。
@Documented
@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
public @interface MyAnnotation1 {
}
上面的作用是定义一个 Annotation,它的名字是 MyAnnotation1。定义了 MyAnnotation1 之后,我们可以在代码中通过 "@MyAnnotation1" 来使用它。 其它的,@Documented, @Target, @Retention, @interface 都是来修饰 MyAnnotation1 的。下面分别说说它们的含义:
(01) @interface
使用 @interface 定义注解时,意味着它实现了 java.lang.annotation.Annotation 接口,即该注解就是一个Annotation。
定义 Annotation 时,@interface 是必须的。
注意:它和我们通常的 implemented 实现接口的方法不同。Annotation 接口的实现细节都由编译器完成。通过 @interface 定义注解后,该注解不能继承其他的注解或接口。
(02) @Documented
类和方法的 Annotation 在缺省情况下是不出现在 javadoc 中的。如果使用 @Documented 修饰该 Annotation,则表示它可以出现在 javadoc 中。
定义 Annotation 时,@Documented 可有可无;若没有定义,则 Annotation 不会出现在 javadoc 中。
(03) @Target(ElementType.TYPE)
前面我们说过,ElementType 是 Annotation 的类型属性。而 @Target 的作用,就是来指定 Annotation 的类型属性。
@Target(ElementType.TYPE) 的意思就是指定该 Annotation 的类型是 ElementType.TYPE。这就意味着,MyAnnotation1 是来修饰"类、接口(包括注释类型)或枚举声明"的注解。
定义 Annotation 时,@Target 可有可无。若有 @Target,则该 Annotation 只能用于它所指定的地方;若没有 @Target,则该 Annotation 可以用于任何地方。
(04) @Retention(RetentionPolicy.RUNTIME)
前面我们说过,RetentionPolicy 是 Annotation 的策略属性,而 @Retention 的作用,就是指定 Annotation 的策略属性。
@Retention(RetentionPolicy.RUNTIME) 的意思就是指定该 Annotation 的策略是 RetentionPolicy.RUNTIME。这就意味着,编译器会将该 Annotation 信息保留在 .class 文件中,并且能被虚拟机读取。
定义 Annotation 时,@Retention 可有可无。若没有 @Retention,则默认是 RetentionPolicy.CLASS。
以上学习内容来自菜鸟教程https://www.runoob.com/w3cnote/java-annotation.html
1.4 注解和XML对比
注解的优势:
配置简单,维护方便,类型安全。缺点是改变实现类比XML困难。
xml的优势:
修改时,不用改源码。不涉及重新编译和部署,对象关系一目了然。
缺点是配置冗长,类型不安全,编译时很难查错,在运行期报错。
Spring管理Bean方式的比较
基于xml配置 | 基于注解配置 | |
---|---|---|
Bean定义 | <bean id = "..." class = "..." /> | @Component 衍生类 @Controller @Service @Repository |
Bean名称 | 通过id或name指定 | @Component("person") |
Bean注入 | <property>或者通过p命名空间 | @Autowired按类型注入 @Qualifier按名称注入 |
生命过程、Bean作用范围 | init-method,destroy-method范围scope属性 | @PostConstruct初始化 @PreDestroy销毁 @Scope设置作用范围 |
适合场景 | Bean来自第三方,使用其他 | Bean的实现类由用户自己开发 |
评论