代理模式(Proxy)

动机:在面向对象时,有些对象由于某种原因,直接访问会给使用者,或者系统结构带来很多麻烦。
增加一层间接层是软件开发中面对不失去透明操作对象的同时来管理/控制这些对象特有的负责性问题常见的解决方法。

案例:追女孩送各种礼物

import java.util.*;

class SchoolGirl
{
	private String name;

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}
	
	
}
class  Pursuit
{
	SchoolGirl mm;
	public Pursuit(SchoolGirl mm)
	{
		this.mm=mm;
	}
	public void GiveDolls()
	{
		System.out.println(mm.getName()+"送你洋娃娃");
	}
	
}
//加入代理
class Proxy1
{
	SchoolGirl mm;
	public Proxy1(SchoolGirl mm)
	{
		this.mm=mm;
	}
	public void GiveDolls()
	{
		System.out.println(mm.getName()+"送你洋娃娃");
	}
}
public class main
{
	public static void main(String[] args) {
		SchoolGirl jiaojiao=new SchoolGirl();
		jiaojiao.setName("李娇娇");
		 Pursuit nanyi=new Pursuit(jiaojiao);
		 nanyi.GiveDolls();
		 //从代码上看男一直接把东西送给娇娇,男一和娇娇是认识的。但是娇娇不认识男一。
		 /*Proxy1 daili=new Proxy1(jiaojiao);
		   daili.GiveDolls();*///这样写表示为代理送给娇娇东西,没有男一的事了
		 
}
}

娇娇不认识男一,显得有点冒犯。

Pursuit 和 Proxy应该实现相同的接口,两者行为一样,代理送的礼物是男一买的。用面向对象的思想考虑要把变化点抽象出来。

class SchoolGirl
{
	private String name;

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}
	
	
}
interface Givegift
{
	void GiveDolls();
}

class  Pursuit implements Givegift
{
	SchoolGirl mm;
	public Pursuit(SchoolGirl mm)
	{
		this.mm=mm;
	}
	public void GiveDolls()
	{
		System.out.println(mm.getName()+"送你洋娃娃");
	}
	
}
//加入代理
class Proxy1 implements Givegift
{
	Pursuit gg;
	public Proxy1(SchoolGirl mm)
	{
		gg=new Pursuit(mm);
	}
	public void GiveDolls()
	{
		gg.GiveDolls();
	}
}//代理替男一送礼物
public class main
{
	public static void main(String[] args) {
		SchoolGirl jiaojiao=new SchoolGirl();
		jiaojiao.setName("李娇娇");
	
		Proxy1 daili=new Proxy1(jiaojiao);
		   daili.GiveDolls();
		 
}
}

 

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

  1. 抽象主题角色:声明了真实主题和代理主题的共同接口,这样在任何使用真实主题的地方都可以使用代理主题。
  2. 代理主题角色: 代理主题角色内部含有对真实主题的引用,从而可以在任何时候操作真实主题对象。
  3. 真实主题角色: 定义了代理角色所代表的真实对象
     

 

abstract class Subject
{
	public abstract void Request();
	
}
class RealSubject extends Subject
{
	public  void Request()
	{
		System.out.println("真实的请求");
	}
}
class Proxy extends Subject
{

	RealSubject realSubject;
	
	@Override
	public void Request() {
		// TODO Auto-generated method stub
		if(realSubject==null)
		{
			realSubject=new RealSubject();
		}
		realSubject.Request();
	}
	
}
public class main
{
	public static void main(String[] args) {
		Proxy proxy=new Proxy();
		proxy.Request();
}
}

在软件系统中,无时不在跨越障碍:当访问网络上一台计算机资源时,需要跨越网络的障碍,当访问服务器上数据库的时候,需要跨越数据库访问障碍还有网络障碍,,Proxy模式有助于解决这些问题

大多数情况下,为了保持对对象操作的透明性,并强制实现类实现代理类所要调用的所有方法,会让它们实现同一个接口。
但是代理类其实只是在一定程度上代表了原来的实现类,所以他们有时候也可以不实现同一个接口。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值