java懒加载注解_在springboot中实现个别bean懒加载的操作

本文介绍了SpringBoot中懒加载的概念及应用,通过示例代码详细解释如何实现个别Bean的懒加载,探讨了懒加载的限制及其对项目启动性能的影响。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

懒加载---就是我们在spring容器启动的是先不把所有的bean都加载到spring的容器中去,而是在当需要用的时候,才把这个对象实例化到容器中。

@Lazy

在需要懒加载的bean上加上@Lazy就可以了

补充知识:springboot组件懒加载的坑及加载规则

什么是懒加载?

懒加载的意思是不在项目启动的时候实例出来这个组件

@RestController

public class ApiController {

@Autowired

Skill kobSkillImpl;

@RequestMapping("/getRust")

public String test(){

kobSkillImpl.print();

return "Welcome Rust's experience";

}

}

首先这是个api的代码

@RestController

public class ApiController {

@Autowired

Skill kobSkillImpl;

@RequestMapping("/getRust")

public String test(){

kobSkillImpl.print();

return "Welcome Rust's experience";

}

}

下面是服务的代码,我们构造函数输出一段内容以便我们知道它是什么时候加载的,我们使用了@lazy注解,标记且启动懒加载

@Service

@Lazy

public class KoaSkillImpl implements Skill {

KoaSkillImpl(){

System.out.println("Load KoaSkill Impl");

}

@Override

public void print() {

System.out.println("I can KOA.js");

}

}

6ae37b6241aff1e05cd7de2557dbbe10.png

在这里就能看到,在项目启动的时候,这个z组件就已经开始初始化了,这个说明什么?这个说明@lazy这个注解在现在是无效的。那么解决的方案是什么?

解决方案是在api层也要加个@lazy,也就是说被调用方是懒加载,但是调用方不是懒加载,最终还不会执行懒加载。

我们在api层也加个@lazy,执行项目发现没有初始化输出的内容了。

那么,在懒加载的作用下,什么时候会初始化?

我们请求一下api的接口,发现控制台已经产生输出,并且对这个类进行了实例化,也就是说懒加载只在使用的时候进行加载,项目启动的时候不会对类实例化。

3daf17c1c773e4207526e14f70a7d4f3.png

2.关于对service多实现类进行加载

@Service

public class JavaSkillImpl implements Skill {

@Override

public void print() {

System.out.println("I Can Java");

}

}

@Service

@Lazy

public class KoaSkillImpl implements Skill {

KoaSkillImpl(){

System.out.println("Load KoaSkill Impl");

}

@Override

public void print() {

System.out.println("I can KOA.js");

}

}

@Service

public class PythonSkillImpl implements Skill {

@Override

public void print() {

System.out.println("I can Python");

}

}

@RestController

@Lazy

public class ApiController {

@Autowired

Skill koaSkillImpl;

@RequestMapping("/getRust")

public String test(){

koaSkillImpl.print();

return "Welcome Rust's experience";

}

}

例子中有三个类,类都实现了ISkill接口,

api中用的是KoaSkillImpl,那么我命名成KobSkillImpl行不行?

当我们这样运行时,项目启动加载的时候是会报错了,其实服务名称是对不上,那么解决方法

1.就是将这个命名改成类名的驼峰

2.就是在@service注解上加@service(“kobSkillImpl”)

3.我们看下@autowired其实是对Api的注入是不?我们有两个主流的注入方法,一个是setter注入,一个是构造函数注入不是?那我们就可以使用构造函数注入的方式对api注入,取代@Autowired这个注解

@RestController

@Lazy

public class ApiController {

Skill javaSkillImpl;

ApiController(Skill javaSkillImpl){

this.javaSkillImpl=javaSkillImpl;

}

@RequestMapping("/getRust")

public String test(){

javaSkillImpl.print();

return "Welcome Rust's experience";

}

}

以上这篇在springboot中实现个别bean懒加载的操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

### 如何在Spring Boot应用程序中正确加载和使用YAML配置文件 #### 加载YAML配置文件的方式 为了使Spring Boot能够识别并解析`.yml`或`.yaml`格式的配置文件,在项目的根目录下创建名为`application.yml`或`application.yaml`的文件即可[^1]。 #### YAML配置文件结构示例 下面是一个简单的`application.yml`文件的例子: ```yaml server: port: 8081 spring: datasource: url: jdbc:mysql://localhost:3306/testdb?useSSL=false&serverTimezone=UTC username: root password: secret ``` 此段代码定义了一个服务器端口以及数据源连接字符串、用户名和密码[^2]。 #### 使用@Value注解读取单个属性值 如果只需要读取少量配置项,则可以采用`@Value`注解来获取特定键对应的值。例如,要访问上面提到的数据源URL,可以在类成员变量上加上如下声明: ```java import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Component; @Component public class DataSourceConfig { @Value("${spring.datasource.url}") private String dbUrl; } ``` 这种方式适用于简单场景下的个别参数注入。 #### 创建自定义Java Bean映射多个属性 对于更复杂的设置或者当存在大量关联紧密的相关选项时,建议通过构建专门的对象模型来进行批量处理。首先定义一个POJO类表示这些配置信息: ```java import lombok.Data; import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.stereotype.Component; @Data @Component @ConfigurationProperties(prefix = "spring.datasource") public class DatabaseSettings { private String url; private String username; private String password; } ``` 接着确保启用了对`ConfigurationProperties`的支持——通常只需让主应用类继承`SpringBootApplication`就足够了;之后就可以像普通Bean那样依赖注入这个新组件实例,并从中方便地获得所需的信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值