采用注解方式开发bean可以省去get、set构造方法同时不需要在xml去添加bean的属性
1.Component注解,这个注解有两种用法,一种是带有name属性值,即Component("xxxx"),一种是直接写这个注解@Component,这两个的区别是:
第一种的注解在getbean的时候取的bianID是@component("xxxx")这个name属性的值,否则报错,第二种使用Component注解,并且不指定其属性name的值,则bena的ID默认为类的名称的第一个字母小写的字符串
将之前的HelloWorld改用注解方式
Hello类用@component注解
![ITWD]9LQ]R12XVZ2S`9LI6V.png](https://upload-images.jianshu.io/upload_images/16513823-e7c5abf5c204f588.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)HelloApp用@componentScan注解
![0}%YO]ZC8Y~PHDOHR7Y_)WQ.png](https://upload-images.jianshu.io/upload_images/16513823-fc2492f53a80308d.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
- 运行结果
![BJRFDPULU~%JQ`@F8$YJHC.png
2.Student和Phone类改成@component注解
- Lombok插件的使用
1.Settings->plugins,搜索Lombok,安装,重启IDEA
2.添加依赖
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.16.18</version>
<scope>provided</scope>
</dependency>
3.使用@Data注解,不用再写那些构造方法、getter/setter,toString()了 使用@Value("")给简单类型赋值.
-
Student类
-
Phone
-
StudentApp
- 运行结果
![)J0A_TN~PLNJ@0]AQW}0AYW.png](https://upload-images.jianshu.io/upload_images/16513823-0c73795474878a4c.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240) - 关于Lombok的进一步学习(摘抄老师的)
有哪些注解?
@Data
@Setter
@Getter
@Log4j
@AllArgsConstructor
@NoArgsConstructor
@EqualsAndHashCode
@NonNull
@Cleanup
@ToString
@RequiredArgsConstructor
@Value
@SneakyThrows
@Synchronized
注解详解
@Data
注解在 类 上;提供类所有属性的 get 和 set 方法,此外还提供了equals、canEqual、hashCode、toString 方法。
@Setter
注解在 属性 上;为单个属性提供 set 方法; 注解在 类 上,为该类所有的属性提供 set 方法, 都提供默认构造方法。
@Getter
注解在 属性 上;为单个属性提供 get 方法; 注解在 类 上,为该类所有的属性提供 get 方法,都提供默认构造方法。
@Log4j
注解在 类 上;为类提供一个 属性名为 log 的 log4j 日志对象,提供默认构造方法。
@AllArgsConstructor
注解在 类 上;为类提供一个全参的构造方法,加了这个注解后,类中不提供默认构造方法了。
@NoArgsConstructor
注解在 类 上;为类提供一个无参的构造方法。
@EqualsAndHashCode
注解在 类 上, 可以生成 equals、canEqual、hashCode 方法。
@NonNull
注解在 属性 上,会自动产生一个关于此参数的非空检查,如果参数为空,则抛出一个空指针异常,也会有一个默认的无参构造方法。
@Cleanup
这个注解用在 变量 前面,可以保证此变量代表的资源会被自动关闭,默认是调用资源的 close() 方法,如果该资源有其它关闭方法,可使用 @Cleanup(“methodName”) 来指定要调用的方法,也会生成默认的构造方法
@ToString
这个注解用在 类 上,可以生成所有参数的 toString 方法,还会生成默认的构造方法。
@RequiredArgsConstructor
这个注解用在 类 上,使用类中所有带有 @NonNull 注解的或者带有 final 修饰的成员变量生成对应的构造方法。
@Value
这个注解用在 类 上,会生成含所有参数的构造方法,get 方法,此外还提供了equals、hashCode、toString 方法。
@SneakyThrows
这个注解用在 方法 上,可以将方法中的代码用 try-catch 语句包裹起来,捕获异常并在 catch 中用 Lombok.sneakyThrow(e) 把异常抛出,可以使用 @SneakyThrows(Exception.class) 的形式指定抛出哪种异常,也会生成默认的构造方法。
@Synchronized
这个注解用在 类方法 或者 实例方法 上,效果和 synchronized 关键字相同,区别在于锁对象不同,对于类方法和实例方法,synchronized 关键字的锁对象分别是类的 class 对象和 this 对象,而 @Synchronized 的锁对象分别是 私有静态 final 对象 lock 和 私有 final 对象 lock,当然,也可以自己指定锁对象,此外也提供默认的构造方法。