@Lazy注解学习

转自:http://blog.51cto.com/4247649/2118337

今天主要从以下几方面来介绍一下@Lazy注解

  • @Lazy注解是什么

  • @Lazy注解怎么使用

 

1,@Lazy注解是什么

 

@Lazy注解用于标识bean是否需要延迟加载,源码如下:

 

 

 

@Target({ElementType.TYPE, ElementType.METHOD, ElementType.CONSTRUCTOR, ElementType.PARAMETER, ElementType.FIELD})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface Lazy {
    /**
     * Whether lazy initialization should occur.
     */
    boolean value() default true;
}

 

 

只有一个参数,默认是true,也就是说只要加了这个注解就会延迟加载

 

2,@Lazy注解怎么使用

 

没加注解之前主要容器启动就会实例化bean,如下:

 

 

 

AnnotationConfigApplicationContext applicationContext2 = new AnnotationConfigApplicationContext(MainConfig.class);

 

 

 

创建user实例

 

 

而加上@Lazy注解则必须在第一次调用的时候才会加载如下:

 

 

 

/**
     * 定义一个bean对象
     * @return
     */
    @Scope
    @Lazy
    @Bean(value="user0",name="user0",initMethod="initUser",destroyMethod="destroyUser")
    public User getUser(){
        System.out.println("创建user实例");
        return new User("张三",26);
    }

 

 

 

 

AnnotationConfigApplicationContext applicationContext2 = new AnnotationConfigApplicationContext(MainConfig.class);
User bean2 = applicationContext2.getBean(User.class);

 

 

 

创建user实例
实例1 === User [userName=张三, age=26]

 

 

@Lazy注解注解的作用主要是减少springIOC容器启动的加载时间

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
抱歉,我没有找到关于elementui懒加载lazy的具体解析的引用内容。但是根据我对懒加载的理解,懒加载是一种延迟加载的技术,它可以在需要时才加载资源,而不是在页面加载时就加载所有的组件或资源。这样可以提高页面的加载速度和性能。在React中,可以使用React.lazy()函数来实现懒加载,它可以动态地加载组件。在使用elementui时,如果想要实现懒加载,可以结合React.lazy()函数和Suspense组件来实现。通过将需要懒加载的组件包装在Suspense组件中,并设置fallback属性来指定在加载组件时显示的加载中的提示信息。这样在访问到该组件时,才会进行加载和渲染。 #### 引用[.reference_title] - *1* [react路由懒加载lazyLoad](https://blog.csdn.net/wanghe1111_/article/details/124599270)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [一分钟学习Spring注解之懒加载@Lazy](https://blog.csdn.net/weixin_34722747/article/details/114897464)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [【React】路由懒加载 React.lazy()](https://blog.csdn.net/m0_63779088/article/details/126202221)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值