- 谷歌 Guice 教程
- Guice - 主页
- Guice - 概览
- Guice - 环境设置
- Guice - 第一个应用程序
- 绑定示例
- Guice - 链接绑定
- Guice - 绑定批注
- Guice - @Named 绑定
- Guice - 常量绑定
- Guice - @Provides 批注
- Guice - 提供程序类
- Guice - 构造函数绑定
- Guice - 内置绑定
- Guice - JIT 绑定
- 注入示例
- Guice - 构造函数注入
- Guice - 方法注入
- Guice - 字段注入
- Guice - 可选注入
- Guice - 按需注入
- 其他示例
- Guice - 范围
- Guice - AOP
- Guice 有用资源
- Guice - 快速指南
- Guice - 有用资源
- Guice - 讨论
谷歌 Guice - 常量绑定
Guice 提供了一种用值对象或常量创建绑定关系的方法。考虑一下我们要配置 JDBC URL 的情况。
使用 @Named 批注注入
@Inject
public void connectDatabase(@Named("JBDC") String dbUrl) {
//...
}
可以使用 toInstance() 方法实现此目的。
bind(String.class).annotatedWith(Names.named("JBDC")).toInstance("jdbc:mysql://:5326/emp");
完整示例
创建一个名为 GuiceTester 的 Java 类。
GuiceTester.java
import com.google.inject.AbstractModule;
import com.google.inject.Guice;
import com.google.inject.Inject;
import com.google.inject.Injector;
import com.google.inject.name.Named;
import com.google.inject.name.Names;
public class GuiceTester {
public static void main(String[] args) {
Injector injector = Guice.createInjector(new TextEditorModule());
TextEditor editor = injector.getInstance(TextEditor.class);
editor.makeConnection();
}
}
class TextEditor {
private String dbUrl;
@Inject
public TextEditor(@Named("JDBC") String dbUrl) {
this.dbUrl = dbUrl;
}
public void makeConnection(){
System.out.println(dbUrl);
}
}
//Binding Module
class TextEditorModule extends AbstractModule {
@Override
protected void configure() {
bind(String.class)
.annotatedWith(Names.named("JDBC"))
.toInstance("jdbc:mysql://:5326/emp");
}
}
输出
编译并运行文件,您将看到以下输出。
jdbc:mysql://:5326/emp
广告