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