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