गूगल गाइड - क्विक गाइड

Guice एक खुला स्रोत, जावा-आधारित निर्भरता इंजेक्शन ढांचा है। यह शांत हल्का है और Google द्वारा सक्रिय रूप से विकसित / प्रबंधित किया जाता है।

निर्भरता अन्तःक्षेपण

हर जावा-आधारित एप्लिकेशन में कुछ ऑब्जेक्ट्स होते हैं जो एक साथ काम करने के लिए एंड-यूज़र को एक कार्य अनुप्रयोग के रूप में प्रस्तुत करने के लिए काम करते हैं। एक जटिल जावा एप्लिकेशन लिखते समय, इन कक्षाओं के पुन: उपयोग की संभावना बढ़ाने के लिए और यूनिट परीक्षण करते समय अन्य वर्गों के स्वतंत्र रूप से परीक्षण करने के लिए आवेदन कक्षाएं अन्य जावा कक्षाओं के रूप में स्वतंत्र होनी चाहिए। निर्भरता इंजेक्शन (या कुछ समय जिसे वायरिंग कहा जाता है) इन वर्गों को एक साथ चमकाने में मदद करता है और साथ ही उन्हें स्वतंत्र रखता है।

विचार करें कि आपके पास एक एप्लिकेशन है जिसमें एक पाठ संपादक घटक है और आप एक वर्तनी जांच प्रदान करना चाहते हैं। आपका मानक कोड कुछ इस तरह दिखेगा -

public class TextEditor {
   private SpellChecker spellChecker;
   
   public TextEditor() {
      spellChecker = new SpellChecker();
   }
}

हमने यहां जो कुछ किया है, वह TextEditor और SpellChecker के बीच निर्भरता पैदा करता है। नियंत्रण परिदृश्य के विलोम में, हम इसके बजाय कुछ ऐसा करेंगे -

public class TextEditor {
   private SpellChecker spellChecker;
   
   @Inject
   public TextEditor(SpellChecker spellChecker) {
      this.spellChecker = spellChecker;
   }
}

यहां, TextEditor को SpellChecker के कार्यान्वयन के बारे में चिंता नहीं करनी चाहिए। SpellChecker को स्वतंत्र रूप से लागू किया जाएगा और उसे TextEditor को इंस्टेंटएडर इंस्टेंटेशन के समय प्रदान किया जाएगा।

निर्भरता इंजेक्शन का उपयोग कर जूँ (बंधन)

डिपेंडेंसी इंजेक्शन को Guice Bindings द्वारा नियंत्रित किया जाता है। Guice अपने वास्तविक कार्यान्वयन के लिए ऑब्जेक्ट प्रकारों को मैप करने के लिए बाइंडिंग का उपयोग करता है। इन बाइंडिंग को एक मॉड्यूल के रूप में परिभाषित किया गया है। एक मॉड्यूल बाइंडिंग का एक संग्रह है जैसा कि नीचे दिखाया गया है:

public class TextEditorModule extends AbstractModule {
   @Override 
   protected void configure() {
      /*
      * Bind SpellChecker binding to WinWordSpellChecker implementation 
      * whenever spellChecker dependency is used.
      */
      bind(SpellChecker.class).to(WinWordSpellChecker.class);
   }
}

मॉड्यूल एक इंजेक्टर के लिए कोर बिल्डिंग ब्लॉक है जो कि Guice का ऑब्जेक्ट-ग्राफ बिल्डर है। पहला स्टेनो एक इंजेक्टर बनाने के लिए है और फिर हम ऑब्जेक्ट्स प्राप्त करने के लिए इंजेक्टर का उपयोग कर सकते हैं।

public static void main(String[] args) {
   /*
   * Guice.createInjector() takes Modules, and returns a new Injector
   * instance. This method is to be called once during application startup.
   */
   Injector injector = Guice.createInjector(new TextEditorModule());
   /*
   * Build object using injector
   */
   TextEditor textEditor = injector.getInstance(TextEditor.class);   
}

उपरोक्त उदाहरण में, TextEditor क्लास ऑब्जेक्ट ग्राफ का निर्माण Guice द्वारा किया गया है और इस ग्राफ में TextWditor ऑब्जेक्ट और WinWordSpellChecker ऑब्जेक्ट के रूप में इसकी निर्भरता है।

स्थानीय पर्यावरण सेटअप

यदि आप अभी भी जावा प्रोग्रामिंग भाषा के लिए अपना वातावरण सेट करने के लिए तैयार हैं, तो यह अनुभाग आपको बताता है कि जावा को अपनी मशीन पर कैसे डाउनलोड और सेट किया जाए। पर्यावरण स्थापित करने के लिए कृपया नीचे दिए गए चरणों का पालन करें।

जावा एसई डाउनलोड जावा से लिंक से स्वतंत्र रूप से उपलब्ध है । इसलिए आप अपने ऑपरेटिंग सिस्टम के आधार पर एक संस्करण डाउनलोड करते हैं।

जावा डाउनलोड करने और चलाने के लिए निर्देशों का पालन करें .exeअपनी मशीन पर जावा स्थापित करने के लिए। एक बार जब आप अपनी मशीन पर जावा स्थापित कर लेते हैं, तो आपको इंस्टॉलेशन निर्देशिकाओं को सही करने के लिए पर्यावरण चर सेट करना होगा -

Windows 2000 / XP के लिए पथ सेट करना

हम मान रहे हैं कि आपने जावा को c: \ Program Files \ java \ jdk डायरेक्टरी में स्थापित किया है -

  • 'मेरा कंप्यूटर' पर राइट-क्लिक करें और 'गुण' चुनें।

  • 'उन्नत' टैब के अंतर्गत 'पर्यावरण चर' बटन पर क्लिक करें।

  • अब, 'Path' वैरिएबल को बदल दें ताकि इसमें जावा एक्जीक्यूटेबल का पथ भी शामिल हो। उदाहरण के लिए, यदि पथ वर्तमान में 'C: \ WINDOWS \ SYSTEM32' पर सेट है, तो 'C: \ WINDOWS \ SYSTEM32; c: \ Program Files \ java \ jdk \ bin' पढ़ने के लिए अपना पथ परिवर्तित करें।

Windows 95/98 / ME के ​​लिए पथ सेट करना

हम मान रहे हैं कि आपने जावा को c: \ Program Files \ java \ jdk डायरेक्टरी में स्थापित किया है -

  • 'C: \ autoexec.bat' फ़ाइल को संपादित करें और अंत में निम्न पंक्ति जोड़ें - 'PATH =% PATH%; C: \ Program Files \ java \ jdk \ bin'

लिनक्स, यूनिक्स, सोलारिस, फ्रीबीएसडी के लिए पथ की स्थापना

जावा चर को स्थापित करने के लिए पर्यावरण चर पथ को निर्धारित किया जाना चाहिए। यदि आपको ऐसा करने में परेशानी होती है, तो अपने शेल दस्तावेज़ देखें।

उदाहरण, यदि आप अपने शेल के रूप में बैश का उपयोग करते हैं, तो आप अपने '.bashrc: PATH = / path / to / java: $ PATH' के अंत में निम्नलिखित पंक्ति जोड़ेंगे।

लोकप्रिय जावा संपादक

अपने जावा प्रोग्राम लिखने के लिए, आपको एक टेक्स्ट एडिटर चाहिए। बाजार में कई परिष्कृत आईडीई उपलब्ध हैं। लेकिन अभी के लिए, आप निम्नलिखित में से एक पर विचार कर सकते हैं -

  • Notepad - विंडोज मशीन पर आप किसी भी साधारण टेक्स्ट एडिटर जैसे नोटपैड (इस ट्यूटोरियल के लिए अनुशंसित), टेक्स्टपैड का उपयोग कर सकते हैं।

  • Netbeans - यह एक जावा आईडीई है जो ओपन-सोर्स और फ्री है जिसे डाउनलोड किया जा सकता है https://www.netbeans.org/index.html।

  • Eclipse - यह ग्रहण खुले स्रोत समुदाय द्वारा विकसित एक जावा आईडीई भी है और इससे डाउनलोड किया जा सकता है https://www.eclipse.org/।

Google Guice Environment

Google Guice और संबंधित जार फ़ाइलों का नवीनतम संस्करण डाउनलोड करें।

  • Google Guice 4.0

  • एओपी एलायंस 1.0

  • अमरूद 16.0.1

  • javax.inject 1.0

इस ट्यूटोरियल को लिखने के समय, हमने उन्हें C: \> Google फ़ोल्डर में कॉपी कर लिया है।

ओएस संग्रह का नाम
खिड़कियाँ guice-4.1.0.jar; aopalliance-1.0.jar; अमरूद-16.0.1.jar; javax.inject-1.jar
लिनक्स guice-4.1.0.jar; aopalliance-1.0.jar; अमरूद-16.0.1.jar; javax.inject-1.jar
मैक guice-4.1.0.jar; aopalliance-1.0.jar; अमरूद-16.0.1.jar; javax.inject-1.jar

CLASSPATH चर सेट करें

ठीक CLASSPATHपर्यावरण चर गुएस जार स्थान को इंगित करने के लिए। यह मानते हुए, आपने विभिन्न ऑपरेटिंग सिस्टम पर Google फ़ोल्डर में Guice और संबंधित जार संग्रहीत किए हैं।

ओएस उत्पादन
खिड़कियाँ वातावरण चर CLASSPATH को% CLASSPATH% में सेट करें; C: \ Google \ guice-4.1.0.jar; C: \ Google \ aopalliance-1.0.jar; C: \ Google \ guava-16.0.1। गूगल \ javax.inject-1.jar;।;
लिनक्स निर्यात CLASSPATH = $ CLASSPATH: Google / guice-4.1.0.jar: Google / aopalliance-1.0.jar: Google / guava-16.0.1.jar: Google / javax.inject-1.jar:।
मैक निर्यात CLASSPATH = $ CLASSPATH: Google / guice-4.1.0.jar: Google / aopalliance-1.0.jar: Google / guava-16.0.1.jar: Google / javax.inject-1.jar:।

चलिए एक नमूना कंसोल आधारित अनुप्रयोग बनाते हैं, जहाँ हम गुइसा बाइंडिंग मैकेनिज्म स्टेप बाई स्टेप का उपयोग करके निर्भरता इंजेक्शन प्रदर्शित करेंगे।

चरण 1: इंटरफ़ेस बनाएँ

//spell checker interface
interface SpellChecker {
   public void checkSpelling();
}

चरण 2: कार्यान्वयन बनाएं

//spell checker implementation
class SpellCheckerImpl implements SpellChecker {
   @Override
   public void checkSpelling() {
      System.out.println("Inside checkSpelling." );
   } 
}

चरण 3: बाइंडिंग मॉड्यूल बनाएं

//Binding Module
class TextEditorModule extends AbstractModule {
   @Override
   protected void configure() {
      bind(SpellChecker.class).to(SpellCheckerImpl.class);
   } 
}

चरण 4: निर्भरता के साथ कक्षा बनाएँ

class TextEditor {
   private SpellChecker spellChecker;
   @Inject
   public TextEditor(SpellChecker spellChecker) {
      this.spellChecker = spellChecker;
   }
   public void makeSpellCheck(){
      spellChecker.checkSpelling();
   }
}

चरण 5: इंजेक्टर बनाएँ

Injector injector = Guice.createInjector(new TextEditorModule());

चरण 6: पूरी की हुई निर्भरता वाली वस्तु प्राप्त करें।

TextEditor editor = injector.getInstance(TextEditor.class);

चरण 7: वस्तु का उपयोग करें।

editor.makeSpellCheck();

पूरा उदाहरण

GuiceTester नाम से एक जावा क्लास बनाएं।

GuiceTester.java

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

public class GuiceTester {
   public static void main(String[] args) {
      Injector injector = Guice.createInjector(new TextEditorModule());
      TextEditor editor = injector.getInstance(TextEditor.class);
      editor.makeSpellCheck(); 
   } 
}

class TextEditor {
   private SpellChecker spellChecker;

   @Inject
   public TextEditor(SpellChecker spellChecker) {
      this.spellChecker = spellChecker;
   }

   public void makeSpellCheck(){
      spellChecker.checkSpelling();
   }
}

//Binding Module
class TextEditorModule extends AbstractModule {

   @Override
   protected void configure() {
      bind(SpellChecker.class).to(SpellCheckerImpl.class);
   } 
}

//spell checker interface
interface SpellChecker {
   public void checkSpelling();
}


//spell checker implementation
class SpellCheckerImpl implements SpellChecker {

   @Override
   public void checkSpelling() {
      System.out.println("Inside checkSpelling." );
   } 
}

उत्पादन

फ़ाइल संकलित करें और चलाएँ, आपको निम्न आउटपुट दिखाई देगा।

Inside checkSpelling.

लिंक्ड बाइंडिंग में, Guice इसके कार्यान्वयन के लिए एक प्रकार का मानचित्र बनाता है। नीचे दिए गए उदाहरण में, हमने SpellChecker इंटरफ़ेस को इसके कार्यान्वयन SpellCheckerImpl के साथ मैप किया है।

bind(SpellChecker.class).to(SpellCheckerImpl.class);

हम कंक्रीट क्लास को उसके उपवर्ग में मैप कर सकते हैं। नीचे दिए गए उदाहरण देखें:

bind(SpellCheckerImpl.class).to(WinWordSpellCheckerImpl.class);

यहाँ हमने बाइंडिंग का पीछा किया है। आइए परिणाम को पूर्ण उदाहरण में देखें।

पूरा उदाहरण

GuiceTester नाम से एक जावा क्लास बनाएं।

GuiceTester.java

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

public class GuiceTester {
   public static void main(String[] args) {
      Injector injector = Guice.createInjector(new TextEditorModule());
      TextEditor editor = injector.getInstance(TextEditor.class);
      editor.makeSpellCheck(); 
   } 
}

class TextEditor {
   private SpellChecker spellChecker;

   @Inject
   public TextEditor(SpellChecker spellChecker) {
      this.spellChecker = spellChecker;
   }

   public void makeSpellCheck(){
      spellChecker.checkSpelling();
   }
}

//Binding Module
class TextEditorModule extends AbstractModule {

   @Override
   protected void configure() {
      bind(SpellChecker.class).to(SpellCheckerImpl.class);
      bind(SpellCheckerImpl.class).to(WinWordSpellCheckerImpl.class);
   } 
}

//spell checker interface
interface SpellChecker {
   public void checkSpelling();
}


//spell checker implementation
class SpellCheckerImpl implements SpellChecker {

   @Override
   public void checkSpelling() {
      System.out.println("Inside checkSpelling." );
   } 
}

//subclass of SpellCheckerImpl
class WinWordSpellCheckerImpl extends SpellCheckerImpl{
   @Override
   public void checkSpelling() {
      System.out.println("Inside WinWordSpellCheckerImpl.checkSpelling." );
   } 
}

उत्पादन

फ़ाइल संकलित करें और चलाएँ, आपको निम्न आउटपुट दिखाई देगा।

Inside WinWordSpellCheckerImpl.checkSpelling.

जैसा कि हम इसके कार्यान्वयन के साथ एक प्रकार बांध सकते हैं। यदि हम कई प्रकार के निहितार्थों के साथ एक प्रकार का नक्शा बनाना चाहते हैं, तो हम कस्टम एनोटेशन भी बना सकते हैं। अवधारणा को समझने के लिए नीचे दिया गया उदाहरण देखें।

एक बंधन एनोटेशन बनाएं

@BindingAnnotation @Target({ FIELD, PARAMETER, METHOD }) @Retention(RUNTIME)
@interface WinWord {}
  • @BindingAnnotation - बाइंडिंग एनोटेशन के रूप में निशान एनोटेशन।

  • @Target - एनोटेशन की प्रयोज्यता के निशान।

  • @Retention - रनटाइम के रूप में एनोटेशन की उपलब्धता।

बाध्यकारी एनोटेशन का उपयोग करके मैपिंग

bind(SpellChecker.class).annotatedWith(WinWord.class).to(WinWordSpellCheckerImpl.class);

बाध्यकारी एनोटेशन का उपयोग करते हुए इंजेक्ट करें

@Inject
public TextEditor(@WinWord SpellChecker spellChecker) {
   this.spellChecker = spellChecker;
}

पूरा उदाहरण

GuiceTester नाम से एक जावा क्लास बनाएं।

GuiceTester.java

import java.lang.annotation.Target;

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

import java.lang.annotation.Retention;

import static java.lang.annotation.RetentionPolicy.RUNTIME;
import static java.lang.annotation.ElementType.PARAMETER;
import static java.lang.annotation.ElementType.FIELD;
import static java.lang.annotation.ElementType.METHOD;

@BindingAnnotation @Target({ FIELD, PARAMETER, METHOD }) @Retention(RUNTIME)
@interface WinWord {}

public class GuiceTester {
   public static void main(String[] args) {
      Injector injector = Guice.createInjector(new TextEditorModule());
      TextEditor editor = injector.getInstance(TextEditor.class);
      editor.makeSpellCheck();     
   } 
}

class TextEditor {
   private SpellChecker spellChecker;   

   @Inject
   public TextEditor(@WinWord SpellChecker spellChecker) {
      this.spellChecker = spellChecker;
   }

   public void makeSpellCheck(){
      spellChecker.checkSpelling(); 
   } 
}

//Binding Module
class TextEditorModule extends AbstractModule {

   @Override
   protected void configure() {
      bind(SpellChecker.class).annotatedWith(WinWord.class)
         .to(WinWordSpellCheckerImpl.class);    
   } 
}

//spell checker interface
interface SpellChecker {
   public void checkSpelling();
}

//spell checker implementation
class SpellCheckerImpl implements SpellChecker {

   @Override
   public void checkSpelling() {
      System.out.println("Inside checkSpelling." );
   } 
}

//subclass of SpellCheckerImpl
class WinWordSpellCheckerImpl extends SpellCheckerImpl{
   @Override
   public void checkSpelling() {
      System.out.println("Inside WinWordSpellCheckerImpl.checkSpelling." );
   } 
}

उत्पादन

फ़ाइल संकलित करें और चलाएँ, आपको निम्न आउटपुट दिखाई देगा।

Inside WinWordSpellCheckerImpl.checkSpelling.

कस्टम अनाउंसमेंट तैयार किए बिना बाइंडिंग को मैप करने के लिए भी Guice एक और तरीका प्रदान करता है। यह @ नामांकित एनोटेशन का उपयोग करने की अनुमति देता है।

नामकरण का उपयोग करके मानचित्रण

bind(SpellChecker.class).annotatedWith(Names.named("OpenOffice")).to(OpenOfficeWordSpellCheckerImpl.class);

@ नामांकित एनोटेशन का उपयोग करते हुए इंजेक्ट करें

@Inject
public TextEditor(@Named("OpenOffice") SpellChecker spellChecker) {
   this.spellChecker = spellChecker;
}

पूरा उदाहरण

GuiceTester नाम से एक जावा क्लास बनाएं।

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.makeSpellCheck();
   } 
}

class TextEditor {
   private SpellChecker spellChecker;
   

   @Inject
   public TextEditor(@Named("OpenOffice") SpellChecker spellChecker) {
      this.spellChecker = spellChecker;      
   }

   public void makeSpellCheck(){
      spellChecker.checkSpelling(); 
   }  
}

//Binding Module
class TextEditorModule extends AbstractModule {

   @Override
   protected void configure() {
      bind(SpellChecker.class).annotatedWith(Names.named("OpenOffice"))
         .to(OpenOfficeWordSpellCheckerImpl.class);
   } 
}

//spell checker interface
interface SpellChecker {
   public void checkSpelling();
}

//spell checker implementation
class SpellCheckerImpl implements SpellChecker {

   @Override
   public void checkSpelling() {
      System.out.println("Inside checkSpelling." );
   } 
}

//subclass of SpellCheckerImpl
class OpenOfficeWordSpellCheckerImpl extends SpellCheckerImpl{
   @Override
   public void checkSpelling() {
      System.out.println("Inside OpenOfficeWordSpellCheckerImpl.checkSpelling." );
   } 
}

उत्पादन

फ़ाइल संकलित करें और चलाएँ, आपको निम्न आउटपुट दिखाई देगा।

Inside OpenOfficeWordSpellCheckerImpl.checkSpelling.

मान मूल्य वस्तुओं या स्थिरांक के साथ बाइंडिंग बनाने का एक तरीका प्रदान करता है। उस मामले पर विचार करें जहां हम JDBC url को कॉन्फ़िगर करना चाहते हैं।

@ नामांकित एनोटेशन का उपयोग करते हुए इंजेक्ट करें

@Inject
public void connectDatabase(@Named("JBDC") String dbUrl) {
   //...
}

यह Instance () विधि का उपयोग करके प्राप्त किया जा सकता है।

bind(String.class).annotatedWith(Names.named("JBDC")).toInstance("jdbc:mysql://localhost:5326/emp");

पूरा उदाहरण

GuiceTester नाम से एक जावा क्लास बनाएं।

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://localhost:5326/emp");
   } 
}

उत्पादन

फ़ाइल संकलित करें और चलाएँ, आपको निम्न आउटपुट दिखाई देगा।

jdbc:mysql://localhost:5326/emp

गाइड @provides पद्धति का उपयोग करके जटिल वस्तुओं के साथ बाइंडिंग बनाने का एक तरीका प्रदान करता है।

@Provides
public SpellChecker provideSpellChecker(){
   String dbUrl = "jdbc:mysql://localhost:5326/emp";
   String user = "user";
   int timeout = 100;
   SpellChecker SpellChecker = new SpellCheckerImpl(dbUrl, user, timeout);
   return SpellChecker;
}

यह मिथोस बाइंडिंग मॉड्यूल का हिस्सा है और मैप किए जाने के लिए जटिल वस्तु प्रदान करता है। नीचे पूरा उदाहरण देखें।

पूरा उदाहरण

GuiceTester नाम से एक जावा क्लास बनाएं।

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.Provides;

public class GuiceTester {
   public static void main(String[] args) {
      Injector injector = Guice.createInjector(new TextEditorModule());
      TextEditor editor = injector.getInstance(TextEditor.class);
      editor.makeSpellCheck();
   } 
}

class TextEditor {
   private SpellChecker spellChecker;
   @Inject
   public TextEditor( SpellChecker spellChecker) {
      this.spellChecker = spellChecker;
   }
   public void makeSpellCheck(){
      spellChecker.checkSpelling();
   } 
}

//Binding Module
class TextEditorModule extends AbstractModule {

   @Override
   protected void configure() {} 

   @Provides
   public SpellChecker provideSpellChecker(){

      String dbUrl = "jdbc:mysql://localhost:5326/emp";
      String user = "user";
      int timeout = 100;

      SpellChecker SpellChecker = new SpellCheckerImpl(dbUrl, user, timeout);
      return SpellChecker;
   }
}

//spell checker interface
interface SpellChecker {
public void checkSpelling();
}

//spell checker implementation
class SpellCheckerImpl implements SpellChecker {

   private String dbUrl;
   private String user;
   private Integer timeout;

   @Inject
   public SpellCheckerImpl(String dbUrl, 
      String user, 
      Integer timeout){
      this.dbUrl = dbUrl;
      this.user = user;
      this.timeout = timeout;
   } 

   @Override
   public void checkSpelling() { 
      System.out.println("Inside checkSpelling." );
      System.out.println(dbUrl);
      System.out.println(user);
      System.out.println(timeout);
   }
}

उत्पादन

फ़ाइल संकलित करें और चलाएँ, आपको निम्न आउटपुट दिखाई देगा।

Inside checkSpelling.
jdbc:mysql://localhost:5326/emp
user
100

जैसा कि @provides विधि अधिक जटिल हो जाती है, इन विधियों को प्रदाता इंटरफ़ेस का उपयोग करके कक्षाओं को अलग करने के लिए ले जाया जा सकता है।

class SpellCheckerProvider implements Provider<SpellChecker>{
   @Override
   public SpellChecker get() {
      String dbUrl = "jdbc:mysql://localhost:5326/emp";
      String user = "user";
      int timeout = 100;
      SpellChecker SpellChecker = new SpellCheckerImpl(dbUrl, user, timeout);
      return SpellChecker;
   } 
}

अगला कदम प्रदाता को टाइप करने के लिए मैप करना है।

bind(SpellChecker.class).toProvider(SpellCheckerProvider.class);

नीचे पूरा उदाहरण देखें।

पूरा उदाहरण

GuiceTester नाम से एक जावा क्लास बनाएं।

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.Provider;

public class GuiceTester {
   public static void main(String[] args) {
      Injector injector = Guice.createInjector(new TextEditorModule());
      TextEditor editor = injector.getInstance(TextEditor.class);
      editor.makeSpellCheck();
   } 
}

class TextEditor {
   private SpellChecker spellChecker;
   @Inject
   public TextEditor( SpellChecker spellChecker) {
      this.spellChecker = spellChecker;
   }

   public void makeSpellCheck(){
      spellChecker.checkSpelling();
   } 
}

//Binding Module
class TextEditorModule extends AbstractModule {

   @Override
   protected void configure() {
      bind(SpellChecker.class)
         .toProvider(SpellCheckerProvider.class);
   } 
}

//spell checker interface
interface SpellChecker {
   public void checkSpelling();
}

//spell checker implementation
class SpellCheckerImpl implements SpellChecker {

   private String dbUrl;
   private String user;
   private Integer timeout;

   @Inject
   public SpellCheckerImpl(String dbUrl, 
      String user, 
      Integer timeout){
      this.dbUrl = dbUrl;
      this.user = user;
      this.timeout = timeout;
   } 

   @Override
   public void checkSpelling() { 
      System.out.println("Inside checkSpelling." );
      System.out.println(dbUrl);
      System.out.println(user);
      System.out.println(timeout);
   }
}

class SpellCheckerProvider implements Provider<SpellChecker>{

   @Override
   public SpellChecker get() {
      String dbUrl = "jdbc:mysql://localhost:5326/emp";
      String user = "user";
      int timeout = 100;

      SpellChecker SpellChecker = new SpellCheckerImpl(dbUrl, user, timeout);
      return SpellChecker;
   }
}

उत्पादन

फ़ाइल संकलित करें और चलाएँ, आपको निम्न आउटपुट दिखाई देगा।

Inside checkSpelling.
jdbc:mysql://localhost:5326/emp
user
100

Guice एक विधि के विशिष्ट निर्माण के साथ बाइंडिंग बनाने के लिए एक तरीका प्रदान करता है () विधि का उपयोग कर।

@Override
protected void configure() {
   try {
      bind(SpellChecker.class)
         .toConstructor(SpellCheckerImpl.class.getConstructor(String.class));
      } catch (NoSuchMethodException | SecurityException e) {
      System.out.println("Required constructor missing");
   } 
}

नीचे पूरा उदाहरण देखें।

पूरा उदाहरण

GuiceTester नाम से एक जावा क्लास बनाएं।

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.makeSpellCheck();
   } 
}

class TextEditor {
   private SpellChecker spellChecker;
   @Inject
   public TextEditor( SpellChecker spellChecker) {
      this.spellChecker = spellChecker;
   }

   public void makeSpellCheck(){
      spellChecker.checkSpelling();
   } 
}

//Binding Module
class TextEditorModule extends AbstractModule {

   @Override
   protected void configure() {
      try {
         bind(SpellChecker.class)
            .toConstructor(SpellCheckerImpl.class.getConstructor(String.class));
      } catch (NoSuchMethodException | SecurityException e) {
         System.out.println("Required constructor missing");
      } 
      bind(String.class)
         .annotatedWith(Names.named("JDBC"))
         .toInstance("jdbc:mysql://localhost:5326/emp");
   } 
}

//spell checker interface
interface SpellChecker {
   public void checkSpelling();
}

//spell checker implementation
class SpellCheckerImpl implements SpellChecker {

   private String dbUrl;

   public SpellCheckerImpl(){}

   public SpellCheckerImpl(@Named("JDBC") String dbUrl){
      this.dbUrl = dbUrl;
   } 

   @Override
   public void checkSpelling() { 
      System.out.println("Inside checkSpelling." );
      System.out.println(dbUrl); 
   }
}

उत्पादन

फ़ाइल संकलित करें और चलाएँ, आपको निम्न आउटपुट दिखाई देगा।

Inside checkSpelling.
jdbc:mysql://localhost:5326/emp

Guice java.util.log.Logger वर्ग के लिए इनबिल्ट बाइंडिंग प्रदान करता है । लकड़हारा का नाम स्वचालित रूप से उस वर्ग के नाम पर सेट हो जाता है जिसमें लकड़हारा इंजेक्ट किया जाता है। नीचे दिए गए उदाहरण देखें।

उदाहरण

GuiceTester नाम से एक जावा क्लास बनाएं।

GuiceTester.java

import java.util.logging.Logger;

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

public class GuiceTester {
   public static void main(String[] args) {
      Injector injector = Guice.createInjector(new TextEditorModule());
      TextEditor editor = injector.getInstance(TextEditor.class);
      editor.makeSpellCheck();
   } 
}

class TextEditor {
   private Logger logger;

   @Inject
   public TextEditor( Logger logger) {
      this.logger = logger;
   }

   public void makeSpellCheck(){
      logger.info("In TextEditor.makeSpellCheck() method");
   } 
}

//Binding Module
class TextEditorModule extends AbstractModule {

   @Override
   protected void configure() {
   } 
}

उत्पादन

फ़ाइल संकलित करें और चलाएँ, आपको निम्न आउटपुट दिखाई देगा।

Dec 20, 2017 12:51:05 PM TextEditor makeSpellCheck
INFO: In TextEditor.makeSpellCheck() method

बाइंडिंग मॉड्यूल में बाइंडिंग को परिभाषित किया गया है, जब भी निर्भरता को इंजेक्ट करने की आवश्यकता होती है, तो Guice उनका उपयोग करता है। यदि मामले में बाइंडिंग मौजूद नहीं है, तो यह समय-समय पर बाइंडिंग बनाने का प्रयास कर सकता है। बाइंडिंग मॉड्यूल में मौजूद बाइंडिंग को स्पष्ट बाइंडिंग कहा जाता है और यह उच्च पूर्वता के होते हैं जबकि समय-समय पर बाइंडिंग को अंतर्निहित बाइंडिंग कहा जाता है। यदि दोनों प्रकार के बाइंडिंग मौजूद हैं, तो मैपिंग के लिए स्पष्ट बाइंडिंग पर विचार किया जाता है।

निम्नलिखित तीन प्रकार के जस्ट-इन-टाइम बाइंडिंग के उदाहरण हैं।

बाइंडिंग प्रकार विवरण
इंजेक्टेबल कंस्ट्रक्टर्स गैर-निजी, नो-तर्क निर्माता केवल-इन-टाइम बाइंडिंग के लिए पात्र हैं। दूसरा तरीका यह है कि एक निर्माता को @ एनोटेशन एनोटेशन के साथ एनोटेट किया जाए।
@ इम्प्लीमेंटेड बाय एनोटेशन @ इम्प्लीमेंटेड बाय एनोटेशन कार्यान्वयन वर्ग के बारे में गार्ड को बताता है। ऐसे मामले में बाइंडिंग मॉड्यूल में कोई बाध्यकारी आवश्यक नहीं है।
@ProvidedBy एनोटेशन @ProvidedBy एनोटेशन कार्यान्वयन वर्ग के प्रदाता के बारे में गाइड को बताता है। ऐसे मामले में बाइंडिंग मॉड्यूल में कोई बाध्यकारी आवश्यक नहीं है।

गैर-निजी, नो-तर्क निर्माता केवल-इन-टाइम बाइंडिंग के लिए पात्र हैं। दूसरा तरीका यह है कि एक निर्माता को @ एनोटेशन एनोटेशन के साथ एनोटेट किया जाए। उदाहरण देखें:

उदाहरण

GuiceTester नाम से एक जावा क्लास बनाएं।

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.makeSpellCheck();
   } 
}

class TextEditor {
   private SpellChecker spellChecker;

   @Inject
   public TextEditor( SpellChecker spellChecker) {
      this.spellChecker = spellChecker;
   }

   public void makeSpellCheck(){
      spellChecker.checkSpelling();
   } 
}

//Binding Module
class TextEditorModule extends AbstractModule {

   @Override
   protected void configure() { 
      bind(SpellChecker.class).to(SpellCheckerImpl.class);
      bind(String.class)
         .annotatedWith(Names.named("JDBC"))
         .toInstance("jdbc:mysql://localhost:5326/emp");
   } 
}

//spell checker interface
interface SpellChecker {
   public void checkSpelling();
}

//spell checker implementation
class SpellCheckerImpl implements SpellChecker {

   @Inject @Named("JDBC")
   private String dbUrl;

   public SpellCheckerImpl(){}

   @Override
   public void checkSpelling() { 
      System.out.println("Inside checkSpelling." );
      System.out.println(dbUrl); 
   }
}

उत्पादन

फ़ाइल संकलित करें और चलाएँ, आपको निम्न आउटपुट दिखाई देगा।

Inside checkSpelling.
jdbc:mysql://localhost:5326/emp

@ इम्प्लीमेंटेड बाय एनोटेशन कार्यान्वयन वर्ग के बारे में गार्ड को बताता है। ऐसे मामले में बाइंडिंग मॉड्यूल में कोई बाध्यकारी आवश्यक नहीं है। उदाहरण देखें:

उदाहरण

GuiceTester नाम से एक जावा क्लास बनाएं।

GuiceTester.java

import com.google.inject.AbstractModule;
import com.google.inject.Guice;
import com.google.inject.ImplementedBy;
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.makeSpellCheck();
   } 
}

class TextEditor {
   private SpellChecker spellChecker;

   @Inject
   public TextEditor( SpellChecker spellChecker) {
      this.spellChecker = spellChecker;
   }

   public void makeSpellCheck(){
      spellChecker.checkSpelling();
   } 
}

//Binding Module
class TextEditorModule extends AbstractModule {

   @Override
   protected void configure() { 
      bind(String.class)
         .annotatedWith(Names.named("JDBC"))
         .toInstance("jdbc:mysql://localhost:5326/emp");
   } 
}

@ImplementedBy(SpellCheckerImpl.class)
interface SpellChecker {
   public void checkSpelling();
}

//spell checker implementation
class SpellCheckerImpl implements SpellChecker {

   @Inject @Named("JDBC")
   private String dbUrl;

   public SpellCheckerImpl(){}

   @Override
   public void checkSpelling() { 
      System.out.println("Inside checkSpelling." );
      System.out.println(dbUrl); 
   }
}

उत्पादन

फ़ाइल संकलित करें और चलाएँ, आपको निम्न आउटपुट दिखाई देगा।

Inside checkSpelling.
jdbc:mysql://localhost:5326/emp

@ProvidedBy एनोटेशन कार्यान्वयन वर्ग के प्रदाता के बारे में गाइड को बताता है। ऐसे मामले में बाइंडिंग मॉड्यूल में कोई बाध्यकारी आवश्यक नहीं है। उदाहरण देखें:

उदाहरण

GuiceTester नाम से एक जावा क्लास बनाएं।

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.ProvidedBy;
import com.google.inject.Provider;

public class GuiceTester {
   public static void main(String[] args) {
      Injector injector = Guice.createInjector(new TextEditorModule());
      TextEditor editor = injector.getInstance(TextEditor.class);
      editor.makeSpellCheck();
   } 
}

class TextEditor {
   private SpellChecker spellChecker;
   @Inject
   public TextEditor( SpellChecker spellChecker) {
      this.spellChecker = spellChecker;
   }

   public void makeSpellCheck(){
      spellChecker.checkSpelling();
   } 
}

//Binding Module
class TextEditorModule extends AbstractModule {

   @Override
   protected void configure() {     
   } 
}

@ProvidedBy(SpellCheckerProvider.class)
interface SpellChecker {
   public void checkSpelling();
}

//spell checker implementation
class SpellCheckerImpl implements SpellChecker {

   private String dbUrl;
   private String user;
   private Integer timeout;

   @Inject
   public SpellCheckerImpl(String dbUrl, 
      String user, 
      Integer timeout){
      this.dbUrl = dbUrl;
      this.user = user;
      this.timeout = timeout;
   } 

   @Override
   public void checkSpelling() { 
      System.out.println("Inside checkSpelling." );
      System.out.println(dbUrl);
      System.out.println(user);
      System.out.println(timeout);
   }
}

class SpellCheckerProvider implements Provider<SpellChecker>{

   @Override
   public SpellChecker get() {
      String dbUrl = "jdbc:mysql://localhost:5326/emp";
      String user = "user";
      int timeout = 100;

      SpellChecker SpellChecker = new SpellCheckerImpl(dbUrl, user, timeout);
      return SpellChecker;
   }
}

उत्पादन

फ़ाइल संकलित करें और चलाएँ, आपको निम्न आउटपुट दिखाई देगा।

Inside checkSpelling.
jdbc:mysql://localhost:5326/emp
user
100

इंजेक्शन एक वस्तु में निर्भरता को इंजेक्ट करने की एक प्रक्रिया है। कंस्ट्रक्टर इंजेक्शन काफी आम है। इस प्रक्रिया में, निर्भरता को कंस्ट्रक्टर के तर्क के रूप में इंजेक्ट किया जाता है। नीचे दिए गए उदाहरण देखें।

GuiceTester नाम से एक जावा क्लास बनाएं।

GuiceTester.java

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

public class GuiceTester {
   public static void main(String[] args) {
      Injector injector = Guice.createInjector(new TextEditorModule());
      TextEditor editor = injector.getInstance(TextEditor.class);
      editor.makeSpellCheck(); 
   } 
}

class TextEditor {
   private SpellChecker spellChecker;

   @Inject
   public TextEditor(SpellChecker spellChecker) {
      this.spellChecker = spellChecker;
   }

   public void makeSpellCheck(){
      spellChecker.checkSpelling();
   }
}

//Binding Module
class TextEditorModule extends AbstractModule {

   @Override
   protected void configure() {
      bind(SpellChecker.class).to(SpellCheckerImpl.class);
   } 
}

//spell checker interface
interface SpellChecker {
   public void checkSpelling();
}


//spell checker implementation
class SpellCheckerImpl implements SpellChecker {

   @Override
   public void checkSpelling() {
      System.out.println("Inside checkSpelling." );
   } 
}

उत्पादन

फ़ाइल संकलित करें और चलाएँ, आपको निम्न आउटपुट दिखाई देगा।

Inside checkSpelling.

इंजेक्शन एक वस्तु में निर्भरता को इंजेक्ट करने की एक प्रक्रिया है। वैल्यू ऑब्जेक्ट को ऑब्जेक्ट पर निर्भरता के रूप में सेट करने के लिए विधि इंजेक्शन का उपयोग किया जाता है। नीचे दिए गए उदाहरण देखें।

उदाहरण

GuiceTester नाम से एक जावा क्लास बनाएं।

import com.google.inject.AbstractModule;
import com.google.inject.Guice;
import com.google.inject.ImplementedBy;
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.makeSpellCheck();
   } 
}

class TextEditor {
   private SpellChecker spellChecker;

   @Inject
   public TextEditor( SpellChecker spellChecker) {
      this.spellChecker = spellChecker;
   }

   public void makeSpellCheck(){
      spellChecker.checkSpelling();
   } 
}

//Binding Module
class TextEditorModule extends AbstractModule {

   @Override
   protected void configure() { 
      bind(String.class)
         .annotatedWith(Names.named("JDBC"))
         .toInstance("jdbc:mysql://localhost:5326/emp");
   } 
}

@ImplementedBy(SpellCheckerImpl.class)
interface SpellChecker {
   public void checkSpelling();
}

//spell checker implementation
class SpellCheckerImpl implements SpellChecker {
 
   private String dbUrl;

   public SpellCheckerImpl(){}
   
   @Inject 
   public void setDbUrl(@Named("JDBC") String dbUrl){
      this.dbUrl = dbUrl;
   }

   @Override
   public void checkSpelling() { 
      System.out.println("Inside checkSpelling." );
      System.out.println(dbUrl); 
   }
}

उत्पादन

फ़ाइल संकलित करें और चलाएँ, आपको निम्न आउटपुट दिखाई देगा।

Inside checkSpelling.
jdbc:mysql://localhost:5326/emp

इंजेक्शन एक वस्तु में निर्भरता को इंजेक्ट करने की एक प्रक्रिया है। फ़ील्ड इंजेक्शन का उपयोग किसी ऑब्जेक्ट के क्षेत्र पर निर्भरता के रूप में मान ऑब्जेक्ट सेट करने के लिए किया जाता है। नीचे दिए गए उदाहरण देखें।

उदाहरण

GuiceTester नाम से एक जावा क्लास बनाएं।

GuiceTester.java

import com.google.inject.AbstractModule;
import com.google.inject.Guice;
import com.google.inject.ImplementedBy;
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.makeSpellCheck();
   } 
}

class TextEditor {
   private SpellChecker spellChecker;

   @Inject
   public TextEditor( SpellChecker spellChecker) {
      this.spellChecker = spellChecker;
   }

   public void makeSpellCheck(){
      spellChecker.checkSpelling();
   } 
}

//Binding Module
class TextEditorModule extends AbstractModule {

   @Override
   protected void configure() { 
      bind(String.class)
         .annotatedWith(Names.named("JDBC"))
         .toInstance("jdbc:mysql://localhost:5326/emp");
   } 
}

@ImplementedBy(SpellCheckerImpl.class)
interface SpellChecker {
   public void checkSpelling();
}

//spell checker implementation
class SpellCheckerImpl implements SpellChecker {

   @Inject @Named("JDBC")
   private String dbUrl;

   public SpellCheckerImpl(){}

   @Override
   public void checkSpelling() { 
      System.out.println("Inside checkSpelling." );
      System.out.println(dbUrl); 
   }
}

उत्पादन

फ़ाइल संकलित करें और चलाएँ, आपको निम्न आउटपुट दिखाई देगा।

Inside checkSpelling.
jdbc:mysql://localhost:5326/emp

इंजेक्शन एक वस्तु में निर्भरता को इंजेक्ट करने की एक प्रक्रिया है। वैकल्पिक इंजेक्शन का मतलब है अगर मौजूद है तो निर्भरता को इंजेक्ट करना। विधि और फ़ील्ड इंजेक्शन वैकल्पिक रूप से निर्भर हो सकते हैं और निर्भरता मौजूद न होने पर कुछ डिफ़ॉल्ट मान होना चाहिए। नीचे दिए गए उदाहरण देखें।

उदाहरण

GuiceTester नाम से एक जावा क्लास बनाएं।

GuiceTester.java

import com.google.inject.AbstractModule;
import com.google.inject.Guice;
import com.google.inject.ImplementedBy;
import com.google.inject.Inject;
import com.google.inject.Injector;
import com.google.inject.name.Named;

public class GuiceTester {
   public static void main(String[] args) {
      Injector injector = Guice.createInjector(new TextEditorModule());
      TextEditor editor = injector.getInstance(TextEditor.class);
      editor.makeSpellCheck();
   } 
}

class TextEditor {
   private SpellChecker spellChecker;

   @Inject
   public TextEditor( SpellChecker spellChecker) {
      this.spellChecker = spellChecker;
   }

   public void makeSpellCheck(){
      spellChecker.checkSpelling();
   } 
}

//Binding Module
class TextEditorModule extends AbstractModule {

   @Override
   protected void configure() {} 
}

@ImplementedBy(SpellCheckerImpl.class)
interface SpellChecker {
   public void checkSpelling();
}

//spell checker implementation
class SpellCheckerImpl implements SpellChecker {

   private String dbUrl = "jdbc:mysql://localhost:5326/emp";

   public SpellCheckerImpl(){}
   
   @Inject(optional=true)
   public void setDbUrl(@Named("JDBC") String dbUrl){
      this.dbUrl = dbUrl;
   }

   @Override
   public void checkSpelling() { 
      System.out.println("Inside checkSpelling." );
      System.out.println(dbUrl); 
   }
}

उत्पादन

फ़ाइल संकलित करें और चलाएँ, आपको निम्न आउटपुट दिखाई देगा।

Inside checkSpelling.
jdbc:mysql://localhost:5326/emp

इंजेक्शन एक वस्तु में निर्भरता को इंजेक्ट करने की एक प्रक्रिया है। इंजेक्टर.जेक्टमेम्बर्स () मेथड का उपयोग करके एक्साइटिंग ऑब्जेक्ट को इनिशियलाइज़ करने के लिए मेथड और फील्ड इंजेक्शन का उपयोग किया जा सकता है । नीचे दिए गए उदाहरण देखें।

उदाहरण

GuiceTester नाम से एक जावा क्लास बनाएं।

GuiceTester.java

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

public class GuiceTester {
   public static void main(String[] args) {
      Injector injector = Guice.createInjector(new TextEditorModule());
      SpellChecker spellChecker = new SpellCheckerImpl();
      injector.injectMembers(spellChecker);
      
      TextEditor editor = injector.getInstance(TextEditor.class);     
      editor.makeSpellCheck();
   } 
}

class TextEditor {
   private SpellChecker spellChecker;

   @Inject
   public void setSpellChecker(SpellChecker spellChecker){
   this.spellChecker = spellChecker;
   }
   public TextEditor() { }

   public void makeSpellCheck(){
      spellChecker.checkSpelling();
   } 
}

//Binding Module
class TextEditorModule extends AbstractModule {

   @Override
   protected void configure() {      
   } 
}

@ImplementedBy(SpellCheckerImpl.class)
interface SpellChecker {
   public void checkSpelling();
}

//spell checker implementation
class SpellCheckerImpl implements SpellChecker {

   public SpellCheckerImpl(){}
   
   @Override
   public void checkSpelling() { 
      System.out.println("Inside checkSpelling." );
   }
}

फ़ाइल संकलित करें और चलाएँ, आपको निम्न आउटपुट दिखाई देगा।

Inside checkSpelling.

जब भी वह अपने डिफ़ॉल्ट व्यवहार के रूप में एक मूल्य की आपूर्ति करता है तो हर बार एक नया उदाहरण देता है। यह स्कोप के माध्यम से कॉन्फ़िगर करने योग्य है। निम्नलिखित स्कोप हैं जो गुइसा का समर्थन करते हैं:

  • @Singleton- आवेदन के जीवनकाल के लिए एकल उदाहरण। @ सिसलिंग ऑब्जेक्ट को थ्रेडसेफ़ होना चाहिए।

  • @SessionScoped- वेब एप्लिकेशन के किसी विशेष सत्र के लिए एकल उदाहरण। @SSScoped ऑब्जेक्ट थ्रेडसेफ़ होना आवश्यक है।

  • @RequestScoped- वेब एप्लिकेशन के किसी विशेष अनुरोध के लिए एकल उदाहरण। @RequestScoped ऑब्जेक्ट को थ्रेडसेफ़ होने की आवश्यकता नहीं है।

स्कैप लगाने का तरीका।

स्कोप को लागू करने के तरीके निम्नलिखित हैं।

कक्षा स्तर पर

@Singleton
class SpellCheckerImpl implements SpellChecker {

   public SpellCheckerImpl(){}
   
   @Override
   public void checkSpelling() { 
      System.out.println("Inside checkSpelling." );
   }
}

विन्यास स्तर पर

bind(SpellChecker.class).to(SpellCheckerImpl.class).in(Singleton.class);

विधि के स्तर पर

@Provides @Singleton
public SpellChecker provideSpellChecker(){

   String dbUrl = "jdbc:mysql://localhost:5326/emp";
   String user = "user";
   int timeout = 100;

   SpellChecker SpellChecker = new SpellCheckerImpl(dbUrl, user, timeout);
   return SpellChecker;
}

उदाहरण

कार्रवाई में वर्ग स्तर पर स्कोप देखते हैं।

@ सिलिंगटन एनोटेशन के साथ परिणाम

GuiceTester नाम से एक जावा क्लास बनाएं।

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.Singleton;

public class GuiceTester {
   public static void main(String[] args) {
      Injector injector = Guice.createInjector(new TextEditorModule());
      SpellChecker spellChecker = new SpellCheckerImpl();
      injector.injectMembers(spellChecker);

      TextEditor editor = injector.getInstance(TextEditor.class);     
      System.out.println(editor.getSpellCheckerId());

      TextEditor editor1 = injector.getInstance(TextEditor.class);     
      System.out.println(editor1.getSpellCheckerId());
   } 
}

class TextEditor {
   private SpellChecker spellChecker;

   @Inject
   public void setSpellChecker(SpellChecker spellChecker){
      this.spellChecker = spellChecker;
   }
   public TextEditor() { }

   public void makeSpellCheck(){
      spellChecker.checkSpelling();
   } 

   public double getSpellCheckerId(){
      return spellChecker.getId();
   }
}

//Binding Module
class TextEditorModule extends AbstractModule {

   @Override
   protected void configure() {   
      bind(SpellChecker.class).to(SpellCheckerImpl.class);
   } 
}

interface SpellChecker {
   public double getId();
   public void checkSpelling();
}

@Singleton
class SpellCheckerImpl implements SpellChecker {

   double id; 
   public SpellCheckerImpl(){
      id = Math.random();    
   }

   @Override
   public void checkSpelling() { 
      System.out.println("Inside checkSpelling." );
   }

   @Override
   public double getId() { 
      return id;
   }
}

फ़ाइल संकलित करें और चलाएँ, आप निम्न आउटपुट देख सकते हैं।

0.3055839187063575
0.3055839187063575

परिणाम के बिना @Singleton एनोटेशन

GuiceTester नाम से एक जावा क्लास बनाएं।

GuiceTester.java

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

public class GuiceTester {
   public static void main(String[] args) {
      Injector injector = Guice.createInjector(new TextEditorModule());
      SpellChecker spellChecker = new SpellCheckerImpl();
      injector.injectMembers(spellChecker);

      TextEditor editor = injector.getInstance(TextEditor.class);     
      System.out.println(editor.getSpellCheckerId());

      TextEditor editor1 = injector.getInstance(TextEditor.class);     
      System.out.println(editor1.getSpellCheckerId());
   } 
}

class TextEditor {
   private SpellChecker spellChecker;

   @Inject
   public void setSpellChecker(SpellChecker spellChecker){
      this.spellChecker = spellChecker;
   }
   public TextEditor() { }

   public void makeSpellCheck(){
      spellChecker.checkSpelling();
   } 

   public double getSpellCheckerId(){
      return spellChecker.getId();
   }
}

//Binding Module
class TextEditorModule extends AbstractModule {

   @Override
   protected void configure() {   
      bind(SpellChecker.class).to(SpellCheckerImpl.class);
   } 
}

interface SpellChecker {
   public double getId();
   public void checkSpelling();
}

class SpellCheckerImpl implements SpellChecker {

   double id; 
   public SpellCheckerImpl(){
      id = Math.random();    
   }

   @Override
   public void checkSpelling() { 
      System.out.println("Inside checkSpelling." );
   }

   @Override
   public double getId() { 
      return id;
   }
}

फ़ाइल संकलित करें और चलाएँ, आप निम्न आउटपुट देख सकते हैं।

0.556007079571739
0.22095011760351602

Google Guice - AOP

एओपी, एस्पेक्ट ओरिएंटेड प्रोग्रामिंग प्रोग्राम लॉजिक को अलग-अलग हिस्सों में तोड़ता है, जिसे तथाकथित चिंता कहा जाता है। फ़ंक्शंस के कई बिंदुओं को फैलाने वाले कार्यों को क्रॉस-कटिंग चिंताएं कहा जाता है और ये क्रॉस-कटिंग चिंताएं आवेदन के व्यावसायिक तर्क से अलग हैं। लॉगिंग, ऑडिटिंग, घोषणात्मक लेनदेन, सुरक्षा, कैशिंग आदि जैसे पहलुओं के विभिन्न सामान्य अच्छे उदाहरण हैं।

OOP में प्रतिरूपकता की प्रमुख इकाई वर्ग है, जबकि AOP में प्रतिरूपकता की इकाई पहलू है। निर्भरता इंजेक्शन आपको एक दूसरे से अपने आवेदन की वस्तुओं को कम करने में मदद करता है और एओपी आपको प्रभावित होने वाली वस्तुओं से क्रॉस-कटिंग चिंताओं को कम करने में मदद करता है। AOP प्रोग्रामिंग भाषाओं जैसे Perl, .NET, Java, और अन्य में ट्रिगर की तरह है। एक आवेदन को रोकने के लिए गाइड इंटरसेप्टर प्रदान करता है। उदाहरण के लिए, जब किसी विधि को निष्पादित किया जाता है, तो आप विधि के निष्पादन से पहले या बाद में अतिरिक्त कार्यक्षमता जोड़ सकते हैं।

महत्वपूर्ण कक्षाएं

  • Matcher- माचिस एक मान को स्वीकार या अस्वीकार करने के लिए एक इंटरफ़ेस है। Guice AOP में, हमें दो मिलानकर्ताओं की आवश्यकता होती है: एक यह परिभाषित करने के लिए कि कौन से वर्ग भाग लेते हैं, और दूसरा उन वर्गों के तरीकों के लिए।

  • MethodInterceptor- MethodInterceptors एक मिलान विधि कहा जाता है जब निष्पादित किया जाता है। वे कॉल का निरीक्षण कर सकते हैं: विधि, इसके तर्क और प्राप्त करने का उदाहरण। हम क्रॉस-कटिंग तर्क प्रदर्शन कर सकते हैं और फिर अंतर्निहित विधि को सौंप सकते हैं। अंत में, हम रिटर्न वैल्यू या अपवाद और रिटर्न का निरीक्षण कर सकते हैं।

उदाहरण

GuiceTester नाम से एक जावा क्लास बनाएं।

GuiceTester.java

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

import org.aopalliance.intercept.MethodInterceptor;
import org.aopalliance.intercept.MethodInvocation;

import com.google.inject.AbstractModule;
import com.google.inject.Guice;
import com.google.inject.Inject;
import com.google.inject.Injector;
import com.google.inject.matcher.Matchers;

public class GuiceTester {
   public static void main(String[] args) {
      Injector injector = Guice.createInjector(new TextEditorModule());
      TextEditor editor = injector.getInstance(TextEditor.class);
      editor.makeSpellCheck(); 
   } 
}

class TextEditor {
   private SpellChecker spellChecker;

   @Inject
   public TextEditor(SpellChecker spellChecker) {
      this.spellChecker = spellChecker;
   }

   public void makeSpellCheck(){
      spellChecker.checkSpelling();
   }
}

//Binding Module
class TextEditorModule extends AbstractModule {

   @Override
   protected void configure() {
      bind(SpellChecker.class).to(SpellCheckerImpl.class);
      bindInterceptor(Matchers.any(), 
         Matchers.annotatedWith(CallTracker.class), 
         new CallTrackerService());
   } 
}

//spell checker interface
interface SpellChecker {
   public void checkSpelling();
}

//spell checker implementation
class SpellCheckerImpl implements SpellChecker {

   @Override @CallTracker
   public void checkSpelling() {
      System.out.println("Inside checkSpelling." );
   } 
}

@Retention(RetentionPolicy.RUNTIME) @Target(ElementType.METHOD)
@interface CallTracker {}

class CallTrackerService implements MethodInterceptor  {

   @Override
   public Object invoke(MethodInvocation invocation) throws Throwable {
      System.out.println("Before " + invocation.getMethod().getName());
      Object result = invocation.proceed();
      System.out.println("After " + invocation.getMethod().getName());
      return result;
   }
}

फ़ाइल संकलित करें और चलाएँ, आप निम्न आउटपुट देख सकते हैं।

Before checkSpelling
Inside checkSpelling.
After checkSpelling