Exemple d'analyse de proxy dynamique et de proxy statique en Java
0. Mode Agent
Pourquoi devrions-nous apprendre le mode Agent ? Il s'agit de la couche inférieure de SpringAOP [SpringAOP et SpringMVC]
Classification des modèles de proxy :
Procuration statique
Procuration dynamique
1. objets L'amélioration de chaque méthode se fait manuellement (le code sera démontré en détail plus tard), ce qui est très peu flexible (par exemple, une fois qu'une nouvelle méthode est ajoutée à l'interface, l'objet cible et l'objet proxy doivent être modifiés) et gênant (doit modifier chaque cible. Chaque classe écrit une classe proxy distincte
). Il existe très peu de scénarios d’application réels et il n’existe pratiquement aucun scénario dans lequel des proxys statiques sont utilisés dans le développement quotidien.Analyse des rôles :
Rôle abstrait : généralement, des interfaces ou des classes abstraites sont utilisées pour résoudre le problème
- Rôle réel : le rôle proxy
- Rôle d'agent : proxy le rôle réel après. proxy le rôle réel, Nous effectuons généralement quelques opérations subsidiaires
- Client : la personne qui accède à l'objet proxy !
- Étapes du code :
1. Interface
public interface Rent { public void rent(); }
//房东 public class Host implements Rent { public void rent() { System.out.println("房东要租房子"); } }
public class Proxy implements Rent{ private Host host; public Proxy() { } public Proxy(Host host) { this.host = host; } public void rent(){ seeHouse(); host.rent(); fare(); } //看房 public void seeHouse(){ System.out.println("中介带你看房"); } //收中介费 public void fare(){ System.out.println("中介收费"); } }
Peut rendre le fonctionnement de vrais personnages plus pur ! Il n'est pas nécessaire de prêter attention à certaines affaires publiques
- Les affaires publiques seront laissées au rôle d'agent ! Réalisez la division du travail en entreprise !
- Quand les services publics se développent, la gestion centralisée est pratique !
- Inconvénients : Un rôle réel générera un rôle de proxy ; du point de vue de la JVM, les proxys statiques transforment les interfaces, les classes d'implémentation et les classes proxy en fichiers de classe réels lors de la compilation.
2. Approfondissez votre compréhension de AOP, le modèle de proxy sous-jacent
3. Proxy dynamiqueLes rôles du proxy dynamique et du proxy statique sont les mêmes
- La classe proxy du proxy dynamique est généré dynamiquement, pas par nous Écrit directement !
- Les proxys dynamiques sont divisés en deux catégories : les proxys dynamiques basés sur les interfaces, les proxys dynamiques basés sur les classes
- basés sur les interfaces ——les proxys dynamiques JDK
- Implémentation du bytecode Java : javasist
- Vous devez comprendre deux classes : Proxy : classe proxy, InvocationHandler : gestionnaire d'appels Du point de vue de la JVM, le proxy dynamique génère dynamiquement le bytecode de classe au moment de l'exécution et est chargé dans le JVM.
- basés sur les classes : les proxys dynamiques cglib
public class Client { public static void main(String[] args) { Host host = new Host(); //代理,代理角色一般会有附属操作! Proxy proxy = new Proxy(host); proxy.rent(); } }
peut rendre le fonctionnement de vrais personnages plus pur ! Il n'est pas nécessaire de s'occuper de certaines affaires publiques
- Les affaires publiques seront laissées au rôle d'agent ! Implémentation
//Proxy是生成动态代理类,提供了创建动态代理类和实例的静态方法,它也是由这些方法创建的所有动态代理类的超类。 //InvocationHandler-- invoke 调用处理程序并返回接口, 是由代理实例的调用处理程序实现的接口 。
Copier après la connexion- 1.
loader
: Class Loader, utilisé pour charger des objets proxy.
2.interfaces
: Certaines interfaces implémentées par la classe proxy loader
:类加载器,用于加载代理对象。
2.interfaces
: 被代理类实现的一些接口;
3.h
: 实现了 InvocationHandler
接口的对象;
要实现动态代理的话,还必须需要实现InvocationHandler
来自定义处理逻辑。 当我们的动态代理对象调用一个方法时,这个方法的调用就会被转发到实现InvocationHandler
接口类的 invoke
方法来调用。
public static Object newProxyInstance(ClassLoader loader, Class<?>[] interfaces, InvocationHandler h){ }
1.proxy :动态生成的代理类
2.method : 与代理类对象调用的方法相对应
3.args : 当前 method 方法的参数
动态代理的例子
1、定义接口
public interface InvocationHandler { Object invoke(Object proxy, Method method, Object[] args) throws Throwable; }
2、实现租房的接口
public interface Rent { public void rent(); }
3、定义一个JDK动态代理类
public class Host implements Rent { @Override public void rent() { System.out.println("房东要租房"); } }
invoke()
方法: 当我们的动态代理对象调用原生方法的时候,最终实际上调用到的是 invoke()
方法,然后 invoke()
方法代替我们去调用了被代理对象的原生方法。
4、获取代理对象的工厂类
public class DebugInvocationHandler implements InvocationHandler { /** * 代理类中的真实对象 */ private final Object target; public DebugInvocationHandler(Object target){ this.target = target; } /** * 当你使用代理对象调用方法的时候实际会调用到这个方法 */ @Override public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { //调用方法前 System.out.println("before method" + method.getName()); Object res = method.invoke(target, args); //调用方法后 System.out.println("after method" + method.getName()); return res; } }
getProxy()
:主要通过Proxy.newProxyInstance()
3.
h
: Implémentation de l'objet d'interface InvocationHandler
; ; Pour implémenter un proxy dynamique, vous devez également implémenter InvocationHandler
pour personnaliser la logique de traitement. Lorsque notre objet proxy dynamique appelle une méthode, l'appel à cette méthode sera transmis à la méthode invoke
de la classe qui implémente l'interface InvocationHandler
.
public class JdkProxyFactory { public static Object getProxy(Object target){ return Proxy.newProxyInstance( target.getClass().getClassLoader(), target.getClass().getInterfaces(), new DebugInvocationHandler(target) ); } }
1.méthode : Correspondant à la méthode appelée par l'objet classe proxy🎜🎜🎜3.🎜args : Paramètres de la méthode actuelle method🎜proxy : Classe proxy générée dynamiquement
2.
Dynamique Exemple de proxy
🎜1. Définir l'interface🎜public static void main(String[] args) { //Rent rent = new Host(); //Rent rentProxy= (Rent) Proxy.newProxyInstance(rent.getClass().getClassLoader(), rent.getClass().getInterfaces(),new DebugInvocationHandler(rent)); Rent rentProxy = (Rent)JdkProxyFactory.getProxy(new Host()); rentProxy.rent(); }
invoke()
: lorsque notre dynamique Lorsque l'objet proxy appelle la méthode native, ce qui est en réalité appelé est la méthode invoke()
, puis la méthode invoke()
appelle la méthode native de l'objet proxy sur notre nom. 🎜🎜4. Obtenez la classe d'usine de l'objet proxy🎜rrreee🎜getProxy()
: obtenez principalement l'objet proxy d'une certaine classe via la méthode Proxy.newProxyInstance()
🎜🎜5. Résultat de l'exécution de l'agent ci-dessus en utilisant 🎜rrreee🎜🎜🎜🎜🎜🎜avant la méthode de location🎜Le propriétaire veut louer🎜après la méthode de location🎜🎜Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Guide du nombre parfait en Java. Nous discutons ici de la définition, comment vérifier le nombre parfait en Java ?, des exemples d'implémentation de code.

Guide de Weka en Java. Nous discutons ici de l'introduction, de la façon d'utiliser Weka Java, du type de plate-forme et des avantages avec des exemples.

Guide du nombre de Smith en Java. Nous discutons ici de la définition, comment vérifier le numéro Smith en Java ? exemple avec implémentation de code.

Dans cet article, nous avons conservé les questions d'entretien Java Spring les plus posées avec leurs réponses détaillées. Pour que vous puissiez réussir l'interview.

Java 8 présente l'API Stream, fournissant un moyen puissant et expressif de traiter les collections de données. Cependant, une question courante lors de l'utilisation du flux est: comment se casser ou revenir d'une opération FOREAK? Les boucles traditionnelles permettent une interruption ou un retour précoce, mais la méthode Foreach de Stream ne prend pas directement en charge cette méthode. Cet article expliquera les raisons et explorera des méthodes alternatives pour la mise en œuvre de terminaison prématurée dans les systèmes de traitement de flux. Lire plus approfondie: Améliorations de l'API Java Stream Comprendre le flux Forach La méthode foreach est une opération terminale qui effectue une opération sur chaque élément du flux. Son intention de conception est

Guide de TimeStamp to Date en Java. Ici, nous discutons également de l'introduction et de la façon de convertir l'horodatage en date en Java avec des exemples.

Les capsules sont des figures géométriques tridimensionnelles, composées d'un cylindre et d'un hémisphère aux deux extrémités. Le volume de la capsule peut être calculé en ajoutant le volume du cylindre et le volume de l'hémisphère aux deux extrémités. Ce tutoriel discutera de la façon de calculer le volume d'une capsule donnée en Java en utilisant différentes méthodes. Formule de volume de capsule La formule du volume de la capsule est la suivante: Volume de capsule = volume cylindrique volume de deux hémisphères volume dans, R: Le rayon de l'hémisphère. H: La hauteur du cylindre (à l'exclusion de l'hémisphère). Exemple 1 entrer Rayon = 5 unités Hauteur = 10 unités Sortir Volume = 1570,8 unités cubes expliquer Calculer le volume à l'aide de la formule: Volume = π × r2 × h (4

Spring Boot simplifie la création d'applications Java robustes, évolutives et prêtes à la production, révolutionnant le développement de Java. Son approche "Convention sur la configuration", inhérente à l'écosystème de ressort, minimise la configuration manuelle, allo
