- 谷歌 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
廣告