Android设计模式之代理模式

一、定义:

为其他对象提供一种代理以控制对这个对象的访问。

二、角色组成:

Subject抽象主题:声明真是主题与代理的共同接口方法,可以是一个抽象类或接口。

RealSubject真实主题:定义了代理表示的真实对象,执行具体的逻辑和方法。

ProxySubject代理:持有对真实主题的引用,实现接口方法中调用真实主题对应的接口方法。

Client客户:使用代理的示例,通过调用代理的方法来实现对真实主题的调用。

三、代理类型:

1.静态代理:手动创建代理类直接持有目标对象的引用。

2.动态代理:运行时动态生成代理类,如JDK的动态代理,CGLIB等。

3.远程代理:跨进程通信的代理,如Android的AIDL机制。

四、简单实现:

静态代理

1.抽象主题

public interface FileLoader {

String readFile(String path);

}

2.真实主题

public class RealFileLoader implements FileLoader {

@Override

public String readFile(String path) {

// 模拟读取文件内容

return "File content: " + path;

}

}

3.代理

public class FileLoaderProxy implements FileLoader {

private RealFileLoader realFileLoader;

private boolean hasPermission;

public FileLoaderProxy(boolean hasPermission) {

this.hasPermission = hasPermission;

}

@Override

public String readFile(String path) {

// 延迟初始化真实对象

if (realFileLoader == null) {

realFileLoader = new RealFileLoader();

}

// 权限校验

if (!hasPermission) {

return "Error: Permission denied!";

}

// 调用真实对象方法

return realFileLoader.readFile(path);

}

}

4.客户端调用

public class Main {

public static void main(String[] args) {

// 有权限的用户

FileLoader proxy1 = new FileLoaderProxy(true);

System.out.println(proxy1.readFile("/data/test.txt"));

// 输出:File content: /data/test.txt

// 无权限的用户

FileLoader proxy2 = new FileLoaderProxy(false);

System.out.println(proxy2.readFile("/data/secret.txt"));

// 输出:Error: Permission denied!

}

}

动态代理

1.抽象主题

public interface DataService {

void saveData(String data);

void deleteData(String id);

}

2.真实主题

public class RealDataService implements DataService {

@Override

public void saveData(String data) {

System.out.println("Saving data: " + data);

}

@Override

public void deleteData(String id) {

System.out.println("Deleting data with ID: " + id);

}

}

3.动态代理执行

public class LoggingHandler implements InvocationHandler {

private Object target; // 目标对象

public LoggingHandler(Object target) {

this.target = target;

}

@Override

public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {

// 记录调用日志

System.out.println("Method called: " + method.getName());

if (args != null) {

System.out.println("Arguments: " + Arrays.toString(args));

}

// 调用真实对象方法

Object result = method.invoke(target, args);

// 记录返回结果

System.out.println("Method completed: " + method.getName());

return result;

}

}

4.生成动态代理调用

public class Main {

public static void main(String[] args) {

// 创建真实对象

DataService realService = new RealDataService();

// 创建动态代理

DataService proxy = (DataService) Proxy.newProxyInstance(

realService.getClass().getClassLoader(),

realService.getClass().getInterfaces(),

new LoggingHandler(realService)

);

// 通过代理调用方法

proxy.saveData("Hello, Proxy!");

proxy.deleteData("123");

}

}

五、优缺点

优点:

1.控制对象访问,增强安全性。

2.支持延迟加载,优化性能。

3.解耦客户端与目标对象

缺点:

1.增加代码复杂度,需要额外增加代理类。

2.动态代理可能降低运行效率。

3.远程代理需要处理网络或跨进程问题。

相关推荐
代码s贝多芬的音符1 小时前
ios android 小程序 蓝牙 CRC16_MODBUS
android·ios·小程序
2501_915918413 小时前
iOS 混淆实战 多工具组合完成 IPA 混淆、加固与工程化落地(iOS混淆|IPA加固|无源码混淆|Ipa Guard|Swift Shield)
android·ios·小程序·https·uni-app·iphone·webview
雨白3 小时前
让协程更健壮:全面的异常处理策略
android·kotlin
Mr_WangAndy4 小时前
C++设计模式_行为型模式_策略模式Strategy
c++·设计模式·策略模式·依赖倒置原则
LoveXming4 小时前
Chapter11—适配器模式
c++·设计模式·适配器模式·开闭原则
Jeled4 小时前
AI: 生成Android自我学习路线规划与实战
android·学习·面试·kotlin
杯莫停丶5 小时前
设计模式之:单例模式
java·单例模式·设计模式
游戏开发爱好者86 小时前
如何系统化掌握 iOS 26 App 耗电管理,多工具协作
android·macos·ios·小程序·uni-app·cocoa·iphone
shaominjin1236 小时前
android在sd卡中可以mkdir, 但是不可以createNewFile
android·开发语言·python
AI科技星6 小时前
垂直原理:宇宙的沉默法则与万物运动的终极源头
android·服务器·数据结构·数据库·人工智能