美文网首页
day02-02 采用注解方式开发bean

day02-02 采用注解方式开发bean

作者: 黑桃_06ea | 来源:发表于2019-03-01 22:23 被阅读0次

    1.Student和Phone用注解实现

    • 使用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注解,简化POJO类,不用再写那些构造方法、getter/setter,toString()了,专注定义属性即可。

    • Phone类
    package com.spring.one;
    import lombok.Data;
    import org.springframework.beans.factory.annotation.Value;
    import org.springframework.stereotype.Component;
    
    @Component
    @Data
    public class Phone {
        //通过@Value注解给简单类型赋值
        @Value("iPhoneX")
        private String brand;
        @Value("666.6")
        private Double prise;
    }
    
    • PhoneApp类
    package com.spring.one;
    import org.springframework.context.ApplicationContext;
    import org.springframework.context.annotation.AnnotationConfigApplicationContext;
    import org.springframework.context.annotation.ComponentScan;
    
    @ComponentScan
    public class PhoneApp {
        public static void main(String[] args){
            ApplicationContext context=new AnnotationConfigApplicationContext(PhoneApp.class);
            Phone phone=context.getBean(Phone.class);
            System.out.println(phone);
        }
    }
    
    • Student类
    package com.spring.one;
    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("WangJie")
        private String name;
        @Value("21")
        private int age;
        // 引用类型,通过@Autowired注入Phone的bean
        @Autowired
        private Phone phone;
    }
    
    • StudentsApp类
    package com.spring.one;
    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);
        }
    }
    
    • 运行结果 day02-10.png
    • log4j日志依赖:

    <!-- log4j日志依赖 -->
            <dependency>
                <groupId>org.slf4j</groupId>
                <artifactId>slf4j-api</artifactId>
                <version>1.6.6</version>
            </dependency>
            <dependency>
                <groupId>org.slf4j</groupId>
                <artifactId>slf4j-log4j12</artifactId>
                <version>1.6.6</version>
            </dependency>
            <dependency>
                <groupId>log4j</groupId>
                <artifactId>log4j</artifactId>
                <version>1.2.16</version>
            </dependency>
    

    注解拓展:

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

    相关文章

      网友评论

          本文标题:day02-02 采用注解方式开发bean

          本文链接:https://www.haomeiwen.com/subject/xoejuqtx.html