Google Guice - AOP


AOP, pemrograman berorientasi Aspek memerlukan pemecahan logika program menjadi bagian-bagian berbeda yang disebut masalah. Fungsi yang menjangkau banyak titik aplikasi disebut masalah lintas sektoral dan masalah lintas sektoral ini secara konseptual terpisah dari logika bisnis aplikasi. Ada berbagai contoh bagus dari aspek seperti logging, audit, transaksi deklaratif, keamanan, caching, dll.

Unit kunci dari modularitas di OOP adalah class, sedangkan di AOP unit modularity adalah aspeknya. Dependency Injection membantu Anda memisahkan objek aplikasi dari satu sama lain dan AOP membantu Anda memisahkan masalah lintas sektor dari objek yang terpengaruh. AOP seperti pemicu dalam bahasa pemrograman seperti Perl, .NET, Java, dan lainnya. Guice menyediakan interseptor untuk mencegat aplikasi. Misalnya, ketika sebuah metode dijalankan, Anda dapat menambahkan fungsionalitas tambahan sebelum atau setelah eksekusi metode.

Kelas Penting

  • Matcher- Matcher adalah antarmuka untuk menerima atau menolak suatu nilai. Di Guice AOP, kita memerlukan dua pencocokan: satu untuk menentukan kelas mana yang berpartisipasi, dan satu lagi untuk metode kelas tersebut.

  • MethodInterceptor- MethodInterceptors dijalankan ketika metode pencocokan dipanggil. Mereka dapat memeriksa panggilan: metode, argumennya, dan contoh penerima. Kita dapat melakukan logika lintas sektor dan kemudian mendelegasikan ke metode yang mendasarinya. Akhirnya, kita dapat memeriksa nilai pengembalian atau pengecualian dan pengembalian.

Contoh

Buat kelas java bernama 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;
   }
}

Keluaran

Kompilasi dan jalankan file, Anda mungkin melihat output berikut.

Before checkSpelling
Inside checkSpelling.
After checkSpelling