跳到主要內容

Guice - Hello World!

這個範例主要了解Guice如何實做Dependency Injection(DI)。

準備

  1. 至Guice官網下載lib包。我下載了 guice-4.0-beta.zip。
  2. 建立一個Eclipse Java Project並把壓縮的內容解壓到Project libs目錄。
  3. 將guice-4.0-beta.tar與javax.inject.jar加入build path中。

第一隻Guice程式

範例程式包含介面IPrintServer、實作類別ConsolePrinter、用戶端PrinterClient與Guice所需要的configuration模組PrinterModule。

PrintService介面:

package org.tonylin.practice.guice;

public interface IPrintService {
	void print(String ... strs);
}

ConsolePrinter提供Console類型服務的PrintService:

package org.tonylin.practice.guice;

public class ConsolePrinter implements IPrintService {

	@Override
	public void print(String... strs) {
		for( String str : strs ){
			System.out.println(str);
		}
	}
}

PrinterClient是使用到PrintService的用戶端,我們必須針對提供注入服務的函式宣告為@Inject:

package org.tonylin.practice.guice;

import com.google.inject.Guice;
import com.google.inject.Inject;
import com.google.inject.Injector;

public class PrinterClient {
	private IPrintService mPrintService = null;
	
	
	@Inject
	public void setPrintService(IPrintService aPrintService){
		mPrintService = aPrintService;
	}
	
	public IPrintService getPrintService(){
		return mPrintService;
	}
	
	public void print(String ... strs){
		mPrintService.print(strs);
	}
	
	public static void main(String[] args) {
		Injector injector = Guice.createInjector(new PrinterModule());
		PrinterClient printerClient = injector.getInstance(PrinterClient.class);
		printerClient.print("test1", "test2");
	}

}

PrinterModule負責建立PrinterClient與實際提供服務類別的連結,在這裡我透過System Propertes去決定我所要注入給PrinterClient的IPrintService實體:

package org.tonylin.practice.guice;

import com.google.inject.Binder;
import com.google.inject.Module;

public class PrinterModule implements Module {
	@Override
	public void configure(Binder binder) {
	    binder.bind(IPrintService.class).to(ConsolePrinter.class);
	}
}

執行PrinterClient的main可以發現test1與test2字串顯示在螢幕上。

友藏內心獨白: 照這樣看來Guice是蠻簡單的!

Notes

  • @ImplementedBy 等效於Module中做Bind to的動作。如果有多個implementation,宣告的就是預設值。
  • @Provider 等效於Module中設定Provider的動作。
  • 用Provider的目的是為了針對同一種interface可能會有不同type的instance,如果將不同type判斷寫在Module邏輯中是不好的。可以把它當simple factory用。
  • 一個APP只會有一個類別會與Injector溝通,APP不會直接與Injector溝通,而是透過此類別與Injector溝通。(把Guice當Service Locator)

留言

這個網誌中的熱門文章

PostgreSQL - Unattended installation on windows

Introduction 要將別人軟體包裝到自己軟體中,不可或缺的東西就是Unattended installation。以Unattended installation來說,我們可以選擇透過Installer的silent mode安裝,也可以透過把目標軟體做成portable的版本。本篇文章分享這兩種方法,教導大家如何將PostgreSQL透過Unattended installation方式安裝到目標系統成為service。 Note. 本篇以PostgreSQL 10.7為例。 Install with installer Tips 安裝程式或反安裝程式的參數,除了可以直接上官網搜尋Installation User Guide以外,也可以直接使用help參數查詢: postgresql- 10.7 - 2 -windows-x64.exe --help Windows安裝程式主要有EnterpriseDB與BigSQL兩種。BigSQL版本安裝元件是透過網路下載且支援參數不如EnterpriseDB版本多,以我們需求來說,我們傾向於使用EnterpriseDB版本。接下來分享給大家安裝與反安裝方法。 Installation @ echo off set INSTALL_DIR =C:\postgres10 set INSTALLER =postgresql- 10.7 - 2 -windows-x64.exe   rem options for installation set SSMDB_SERVICE =postgresql- 10 set MODE =--unattendedmodeui none --mode unattended   set DB_PASSWD =--superpassword postgres set DB_PORT =--serverport 5432   set SERVICE_NAME =--servicename % SSMDB_SERVICE %   set PREFIX =--prefix "%INSTALL_DIR%" set DATA_DIR =--datadir "%INSTALL_DIR%\data"   set OPTIONS =

How to install RIDE on Windows?

Introduction 多年沒在Windows上開發RobotFramework,趁著這次整理一下RIDE安裝方法。 目前RIDE最新版本與Python對應版本如下: (3.6 < python <= 3.11) Install current released version (2.0.8.1) with: pip install -U robotframework-ride 安裝Python 直接到Python官網找尋最新的3.11版本,我使用3.11.9: link 。安裝就是一直下一步而已。 安裝wxPython 每次安裝RIDE最困難的都是wxPython。看了一下 官網 描述,我就姑且相信一下: 接著進入下 載頁面 就有安裝教學。基本上就是到Python目錄下的Scripts直接執行以下command: pip install -U wxPython 安裝RIDE 接著就如RIDE官網所說,執行以下command: pip install -U robotframework-ride 啟動RIDE 直接在相同目錄下執行ride就可以啟動了,你也可以直接在桌面建ride連結,加快下次啟動時間。 沒想到這次這麼順利就安裝完成了。因為我是使用java去啟動robot framework,就不特別講要怎麼使用pip安裝robot framework了。

Hello World!

即將要搬家,因此舊網頁內容將慢慢轉移至Blogger。 如果要存取舊網頁,可以使用以下連結: https://wiki.tonylin.idv.tw/dokuwiki/doku.php