第二天复习的内容便是各类注解以及通过注解的方式实现Spring的IOC和DI
注解回顾
-
注解的概念
注解是给人看的信息,人看了提示信息了解程序的内容 -
jdk内置注解
- @Override 声明重写父类方法的注解
- @Deprecated 声明方法使用过时,不建议使用
- @SuppressWarnings 压制警告,提示编译器在编译的过程中对指定类型的警告不再提示
-
自定义注解开发
- 开发一个注解类:
开发一个注解类的过程类似鱼开发一个接口,只不过需要通过@interface关键字来声明 - 使用元注解修饰注解的声明
所谓的元注解是用来修饰注解声明的注解,可以控制被修饰的注解的特性。- @Target
用来声明被修饰的注解可以用子什么位置 - @Retention
用来声明修饰的注解会被保留到什么阶段,属性有:- RetentionPolicy.CLASS
这种注解会保留到源码阶段,.java中,在编译的过程中被删除 - RetentionPolicy.CLASS
此注解将会保留在源码阶段和编译阶段, .java和.class中,在类加载的过程中被删除 - RetentiongPolicy.RUNTIME
此注解会保留在源码阶段、编译阶段和运行阶段,.java .class 字节码中都会存在
- RetentionPolicy.CLASS
- @Documented
用来声明被修饰的注解是否要被文档提取工具提取到文档中 - @Inherited
被修饰的注解是否具有继承性
- @Target
- 为注解增加属性
注解类中还可以声明属性。
为注解类声明属性的过程类似于为接口定义方法
- 开发一个注解类:
-
反射注解
- 反射注解原理
RetentionPolicy.RUNTIME级别的注解会保留到运行期,可以通过反射技术获取,从而可以根据是否有注解或注解属性值的不同控制程序按照不同方式运行
- 反射注解原理
isAnnotationPresent | 如果指定类型的注释存在于此元素上,返回true,否则false |
---|---|
getAnnotation | 如果存在该元素的指定类型的注释,则返回这些注释,否则返回null |
getAnnotations | 返回此元素上存在的所有注释 |
Spring注解
概念
spring除了默认的使用xml配置文件的方式实现配置之外,也支持使用注解方式实现配置,这种方式效率更高,配置跟清晰
引入context命名空间
xmlns:context=“http://www.springframework.org/schema/context”
使用注解的方式实现IOC
- 开启包扫描
<context:component-scan base-package="com.zhe.*"/>
- 使用注解注册bean
在配置包的类上使用@Component注解,这个类会被自动注册为bean,使用当前类的class为bean的class
@Component("s")
public class ProductService {
public void doSomeService(){
System.out.println("ProductService");
}
}
- bean的id
通常情况下注解注册bean使用类名首字母小写为bean的id,但是如果类名的第二个字母为大写则首字母保留原样
通过@Component中配置value属性,明确指定bean的id
Spring 注解方式实现DI
- 配置文件中开启使用DI
<!--开启注解配置DI-->
<context:annotation-config></context:annotation-config>
-
注解方式注入spring内置支持的类型数据-非集合类型
方式:@Value
但是,这种方式将注入的值写死在了代码中,后续如果要修改就要修改源代码,所以我们可以使用外部文件的方式,即使用properties配置文件,后续再导入 -
注解方式注入spring内置支持的类型数据-集合类型
- spring-util包
- 注册util标签数据
- 使用:@Value("#{@id}")
使用注解注入自定义的bean数据类型
在bean中的属性上通过@Autowired实现自定义bean类型属性注入代码
当Spring容器解析到@Component注解时,创建当前类的bean在spring容器中进行管理,在创建bean的过程中发现了@Autowired注解,会根据当前bean属性名称,寻找在spring中是否存在id等于该名称的bean,如果存在就自动注入。如果不存在,再检查是否存在和当前bean属性类型相同的bean,如果存在就注入进来,如果不存在则抛出异常。
自动配置:
组件装配< context:component-scan>元素还会自动注册AutowireAnnotationBeanPostProcessor实例,该实例可以自动装配具有**@Autowired**和@Resource、@Inject注解属性。
@Autowired使用的次数最多
@Autowired注解自动装配具有兼容类型的单个Bean属性
- 构造器,普通字段(即使是非public),具有参数的方法都可以应用@Autowired注解
- 默认情况下,所有使用@Autowired注解的属性都需要被设置,当spring找不到匹配的bean装配属性时,会抛出异常,若某一属性不允许不被设置,可以设置@Autowired注解的required属性为false
@Autowired(required = false) 这种方式可以在注解类没有配置好的时候渐少对于异常的问题
- 默认情况下,当IOC容器里存在多个类型兼容的bean时,通过类型的主动装配将无法工作,此时可以在@Qualifiter已指定注入Bean的名称
如果没有指定bean,会优先寻找同名的类,@Qualifier(“userJdbcReposidtory”)可以选择指定的bean
- @Autowired注解也可以应用在数组类型的属性上,此时spring将会把所有匹配的bean进行自动装配
- @Authwired注解也可以应用在集合属性上,此时spring读取集合的类型信息,然后自动装配与之兼容的bean
- @Autowired注解用在java.util.Map上时,若该Map的键值为string,那么spring将自动装配与之Map值类型兼容的bean,此时bean的名称作为键值
<!--自动装配-->
<!-- 配置自动扫描的包 -->
<context:component-scan base-package="com.zhe.spring.jdbc">
</context:component-scan>
其它注解
- @Controller
web层注解 - @Service
service层注解 - @Repository
dao层注解 - @Component
通用的注解
功能是一样的,作用是为了控制代码的规范