五.注释注解

2019-03-02  本文已影响0人  A_x_A

Spring从3.0开始使用注解,到Spring5.0,已经大量使用,注解的使用可以省却大量的xml文件

1.HelloWorld的例子改成用注解来实现

package com.spring.quickstart.xml;

import org.springframework.stereotype.Component;

/*
* 采用注解开发的bean
* @Component用于类级别注解,标注本来为一个可被Spring容器托管的bean
* */
@Component
public class Hello {
    public String getHello(){
        return "Hello Wrold";
    }
}

package com.spring.quickstart.xml;


import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;
import org.springframework.context.annotation.ComponentScan;

/*
* @ComponentScan用于寻找Component注解的bean
* */
@ComponentScan
public class HelloApp {
    public static void main(String[] args) {
        //1.通过注解创建上下文对象bean
        ApplicationContext context = new AnnotationConfigApplicationContext(HelloApp.class);
        //2.读取bean
        Hello hello = context.getBean(Hello.class);
        //3.运行
        System.out.println(hello.getHello());
    }
}

2.Student和Phone的例子改为注解实现

<dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.16.18</version>
            <scope>provided</scope>
        </dependency>
  1. 使用@Data注解,简化POJO类,不用再写那些构造方法、getter/setter,toString()了,专注定义属性即可。
package com.spring.quickstart.xml;

import lombok.Data;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;

/*
* 采用注解和Lombok开发的phone类
* */
@Component
@Data
public class Phone {
    @Value("iphoneX")
    private String brand;

    @Value("6666.66")
    private double price;
}

package com.spring.quickstart.xml;

import lombok.Data;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;

@Component
@Data
public class Student {
    @Value("Tom")
    private String name;

    @Value("20")
    private int age;

    //使用 注入一个phone类
    @Autowired
    private Phone phone;

}

package com.spring.quickstart.xml;

import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;
import org.springframework.context.annotation.ComponentScan;

@ComponentScan
public class StudentApp {
    public static void main(String[] args) {
        ApplicationContext context = new AnnotationConfigApplicationContext(StudentApp.class);

        Student student = context.getBean(Student.class);

        System.out.println(student);
    }
}

其他的一些注解

@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,当然,也可以自己指定锁对象,此外也提供默认的构造方法。

上一篇下一篇

猜你喜欢

热点阅读