代理工厂模式(静态与动态代理)

代理工厂模式

1.静态代理工厂设计模式基础版

所谓代理模式,就是两个子类共同实现一个接口,其中一个子类负责真实业务实现,另外一个子类完成辅助真实业务主题的操作。
代理模式的核心就是代理类接收了真实类的一个对象,从而保证了核心业务的实现,然后再通过代理类的辅助方法完成对真实业务的修饰,然后再通过一个工厂类来产生我们需要的对象(工厂模式);

本篇文章主要讲述代理模式,但我在其中也加上了基础工厂(很简单);

package com.bitten.file.factory;

/**
 * @Author : YangY
 * @Description :
 * @Time : Created in 11:50 2019/4/5
 */
interface ISubject {
   
    void eat();
}
class RealSubject implements ISubject {
   
    @Override
    public void eat() {
   
        System.out.println("吃饭饭!");
    }
}
class ProxySubject implements ISubject {
   
    //用来接收真实业务的对象
    ISubject subject;
    public ProxySubject(ISubject subject) {
   
        this.subject = subject;
    }
    public void beforeEat() {
   
        System.out.println("饭前打豆豆!");
    }
    public void afterEat() {
   
        System.out.println("饭后洗刷刷!");
    }
    @Override
    public void eat() {
   
        beforeEat();
        this.subject.eat();
        afterEat();
    }
}
//工厂
class Factory {
   
    public static Object newInstance() {
   
        return new ProxySubject(new RealSubject());
    }
}
public class TestProxy {
   
    public static void main(String[] args) {
   
        ISubject sub = (ISubject) Factory.newInstance();
        sub.eat();
    }
}

2.静态代理用反射机制实现

下面的代理模式运用上了我们的反射,本质还是跟静态代理一样,只是变了变形式;

package www.bitten.java;

import java.lang.reflect.Constructor;
import java.lang.reflect.InvocationTargetException;

/**
 * @Author : YangY
 * @Description : 代理工厂与反射
 * @Time : Created in 18:31 2019/3/29
 */

interface ISubject {
   
    void eat();
}
//真实业务类
class RealSubject 
  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我来回答您的问题。 1. Java实现适配器模式: 适配器模式是一种结构型设计模式,它允许接口不兼容的对象之间进行合作。在Java中,可以通过以下方式实现适配器模式: ```java public interface Target { void request(); } public class Adaptee { public void specificRequest() { System.out.println("Adaptee specificRequest"); } } public class Adapter implements Target { private Adaptee adaptee; public Adapter(Adaptee adaptee) { this.adaptee = adaptee; } @Override public void request() { adaptee.specificRequest(); } } ``` 2. Java实现三种工厂模式工厂模式是一种创建型设计模式,它提供了一种创建对象的最佳方式。Java中有三种常见的工厂模式:简单工厂模式、工厂方法模式和抽象工厂模式。 (1)简单工厂模式 ```java public interface Product { void use(); } public class ConcreteProduct1 implements Product { @Override public void use() { System.out.println("Use ConcreteProduct1"); } } public class ConcreteProduct2 implements Product { @Override public void use() { System.out.println("Use ConcreteProduct2"); } } public class SimpleFactory { public static Product createProduct(String type) { if ("1".equals(type)) { return new ConcreteProduct1(); } else if ("2".equals(type)) { return new ConcreteProduct2(); } else { return null; } } } ``` (2)工厂方法模式 ```java public interface Product { void use(); } public class ConcreteProduct1 implements Product { @Override public void use() { System.out.println("Use ConcreteProduct1"); } } public class ConcreteProduct2 implements Product { @Override public void use() { System.out.println("Use ConcreteProduct2"); } } public interface Factory { Product create(); } public class ConcreteFactory1 implements Factory { @Override public Product create() { return new ConcreteProduct1(); } } public class ConcreteFactory2 implements Factory { @Override public Product create() { return new ConcreteProduct2(); } } ``` (3)抽象工厂模式 ```java public interface ProductA { void use(); } public class ConcreteProductA1 implements ProductA { @Override public void use() { System.out.println("Use ConcreteProductA1"); } } public class ConcreteProductA2 implements ProductA { @Override public void use() { System.out.println("Use ConcreteProductA2"); } } public interface ProductB { void use(); } public class ConcreteProductB1 implements ProductB { @Override public void use() { System.out.println("Use ConcreteProductB1"); } } public class ConcreteProductB2 implements ProductB { @Override public void use() { System.out.println("Use ConcreteProductB2"); } } public interface Factory { ProductA createProductA(); ProductB createProductB(); } public class ConcreteFactory1 implements Factory { @Override public ProductA createProductA() { return new ConcreteProductA1(); } @Override public ProductB createProductB() { return new ConcreteProductB1(); } } public class ConcreteFactory2 implements Factory { @Override public ProductA createProductA() { return new ConcreteProductA2(); } @Override public ProductB createProductB() { return new ConcreteProductB2(); } } ``` 3. Java实现三种单例模式: 单例模式是一种创建型设计模式,它确保一个类只有一个实例,并提供了全局访问点。Java中有三种常见的单例模式:饿汉式、懒汉式和双重检查锁定。 (1)饿汉式 ```java public class Singleton { private static final Singleton instance = new Singleton(); private Singleton() {} public static Singleton getInstance() { return instance; } } ``` (2)懒汉式 ```java public class Singleton { private static Singleton instance; private Singleton() {} public static synchronized Singleton getInstance() { if (instance == null) { instance = new Singleton(); } return instance; } } ``` (3)双重检查锁定 ```java public class Singleton { private static volatile Singleton instance; private Singleton() {} public static Singleton getInstance() { if (instance == null) { synchronized (Singleton.class) { if (instance == null) { instance = new Singleton(); } } } return instance; } } ``` 4. Java实现两种代理模式: 代理模式是一种结构型设计模式,它提供了一个代理对象来控制对原始对象的访问。Java中有两种常见的代理模式:静态代理动态代理。 (1)静态代理 ```java public interface Subject { void request(); } public class RealSubject implements Subject { @Override public void request() { System.out.println("RealSubject request"); } } public class Proxy implements Subject { private RealSubject realSubject; public Proxy(RealSubject realSubject) { this.realSubject = realSubject; } @Override public void request() { System.out.println("Proxy request"); realSubject.request(); } } ``` (2)动态代理 ```java public interface Subject { void request(); } public class RealSubject implements Subject { @Override public void request() { System.out.println("RealSubject request"); } } public class MyInvocationHandler implements InvocationHandler { private Object target; public MyInvocationHandler(Object target) { this.target = target; } @Override public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { System.out.println("Proxy request"); return method.invoke(target, args); } } public class ProxyTest { public static void main(String[] args) { RealSubject realSubject = new RealSubject(); InvocationHandler handler = new MyInvocationHandler(realSubject); Subject subject = (Subject) Proxy.newProxyInstance(handler.getClass().getClassLoader(), realSubject.getClass().getInterfaces(), handler); subject.request(); } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值