Android RoboGuice 使用指南(10): Just-in-time Bindings

本文深入探讨了依赖注入(DI)机制中的关键概念,包括Injector如何通过显式绑定和即时绑定创建实例,以及@ImplementedBy和@ProvidedBy注解的用法。通过具体的例子,如Android RoboGuice的使用,解释了这些机制如何工作。

Injector 通过检查bindings 定义来创建某个类型的实例对象。定义在Module中的绑定称为“明确声明绑定(Explicit bindings”。Injector 会首先使用带有Explicit Bindings为某个类型创建实例对象。 当但某个类型没有明确定义绑定时,Injector 试图构造“即时绑定(Just-in-time Bindings),JIT Bindings 也成为隐含绑定(implicit bindings).

Eligible Constructor

Injector 通过使用类的injectable constructor 来创建该类的实例对象。injectable constructor 可以为该类定义的public 不带参数的构造函数或是带有@Injector 标记的构造函数。

比如Android RoboGuice 使用指南(4):Linked Bindings中MyRectangle的无参数构造函数:

public class MyRectangle extends Rectangle{
 public MyRectangle(){
 super(50,50,100,120);
 }
 ...
}


Android RoboGuice 使用指南(6):Instance Bindings 定义的含@Injector 标记的构造函数:

public class MySquare extends MyRectangle {
 @Inject public MySquare(@Named("width") int width){
 super(width,width);
 }
}


 

@ImplementedBy
 
该标记通知Injector某个类型的缺省实现,其功能和Linked Bindings 类似,例如:


 

@ImplementedBy(PayPalCreditCardProcessor.class)
public interface CreditCardProcessor {
 ChargeResult charge(String amount, CreditCard creditCard)
 throws UnreachableException; }


 

bind(CreditCardProcessor.class) .to(PayPalCreditCardProcessor.class);


 

等效。 如果某个类型同时含有@ImplementedBy 和bind 定义,将优先使用bind 中的定义。

注: @ImplementedBy 定义了从Interface到实现的依赖,一般不建议使用。

@ProvidedBy

@ProvidedBy 通知Injector 某个类型使用那个缺省Provider来创建实例对象,例如:

@ProvidedBy(DatabaseTransactionLogProvider.class)
public interface TransactionLog {
 void logConnectException(UnreachableException e);
 void logChargeResult(ChargeResult result);
}

和下面Binding等效:


bind(TransactionLog.class)
 .toProvider(DatabaseTransactionLogProvider.class);


 

 和@ImplementedBy 一样,如果同时定义了@ProvidedBy和bind,模块中定义的bind 优先

你提供的 `application.yml` 配置中 **没有注册到 Nacos 的配置项**,也就是说: > ✅ **这个服务目前没有注册到 Nacos。** --- ## 📌 一、如何判断是否注册到 Nacos? 要让一个 Spring Boot 项目注册到 Nacos,必须满足以下条件: ### ✅ 1. 引入 Nacos 客户端依赖(`spring-cloud-starter-alibaba-nacos-discovery`) ```xml <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> <version>2022.0.0.0</version> <!-- 根据你的 Spring Cloud 版本选择 --> </dependency> ``` ### ✅ 2. 在 `application.yml` 或 `bootstrap.yml` 中配置 Nacos 注册中心 ```yaml spring: cloud: nacos: discovery: server-addr: 127.0.0.1:8848 # Nacos Server 地址 ``` --- ## 📝 二、你当前配置分析 你提供的配置如下: ```yaml spring: application: name: domian-display-hjh cloud: stream: bindings: webEvent: destination: data.mqtt content-type: application/json binder: data-in-binder rabbit: bindings: webEvent: producer: exchangeType: topic routingKeyExpression: headers.rk binders: data-in-binder: type: rabbit rabbitmq: requested-heartbeat: 10 addresses: cluster-001:5672,cluster-002:5672,cluster-003:5672 username: yaxt password: yaxt-mq ``` 这部分配置说明: - 使用了 `Spring Cloud Stream`,绑定器是 `RabbitMQ` - 配置了多个 RabbitMQ 地址,使用了用户名和密码 - **没有出现 `nacos` 相关的配置项** --- ## ✅ 三、如何让这个服务注册到 Nacos? ### 步骤 1:添加依赖(`pom.xml`) ```xml <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> <version>2022.0.0.0</version> </dependency> ``` ### 步骤 2:在 `application.yml` 中添加 Nacos 配置 ```yaml spring: cloud: nacos: discovery: server-addr: 127.0.0.1:8848 # Nacos Server 地址 ``` ### 步骤 3:启动类添加注解 ```java @SpringBootApplication @EnableDiscoveryClient public class DomianDisplayHjhApplication { public static void main(String[] args) { SpringApplication.run(DomianDisplayHjhApplication.class, args); } } ``` --- ## 📌 四、补充说明 - `@EnableDiscoveryClient` 是启用服务注册与发现的注解 - `spring.cloud.nacos.discovery.server-addr` 是注册到 Nacos 的地址 - 如果你使用了 `bootstrap.yml`,也可以把 Nacos 配置写在里面 --- ## ✅ 总结 | 是否注册到 Nacos | 说明 | |------------------|------| | ❌ 当前未注册 | 没有引入 `nacos-discovery` 依赖,也没有配置 `nacos.server-addr` | | ✅ 可以注册 | 添加依赖 + 配置 + 启动类注解即可 | ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值