java框架基础 静态代理和动态代理





首先我想说一下,类加载器和反射一个类的区别
class类加载器
xxx.getClass().getClassLoader(); 先通过反射获得,一个类,通过类加载器来加载一个类的同时创建出一个类,而getClass一个类只可以获得这个类中的方法和属性.


class用getclass;  反射获得一个类,getClass一个类只可以获得这个类中的方法和属性.




1、代理模式的分类:
代理模式的定义:为其他对象提供一种代理以控制对这个对象的访问。在某些情况下,一个对象不适合或者不能直接引用另一个对象,而代理对象可以在客户端和目标对象之间起到中介的作用。
代理分为“静态代理”和“动态代理”:静态代理需要我们自己创建代理对象(需要创建代理类),而动态代理的代理对象是自动生成的,我们不需要关系代理对象的生成过程。




2、代理模式中有“抽象角色(接口)”、“代理角色”、“真实角色(目标角色)”这三个角色,代理对象和真实对象都会去实现“抽象角色”这个接口,     也就是说代理模式是基于接口来实现的。




3、对代理对象的理解,和代码的实现



静态代理

package com.my.proxy;


/*
 * 抽象角色(接口)
 */
public interface IProduct {
	public int product();


}






package com.my.proxy;


//目标对象,真实对象
public class LiLingFactory implements IProduct{


	@Override
	public int product() {
		// TODO Auto-generated method stub
		int product=100;
		System.out.println("我要买鞋子,价格要低于"+product);
		return product;
	}


}






package com.my.proxy;


//代理对象,作为直接对象的代理,静态代理
public class LiLingStore implements IProduct {


	@Override
	public int product() {
		// TODO Auto-generated method stub
		LiLingFactory lf=new LiLingFactory();
		int product = lf.product();
		return product*3;
	}


}




package com.my.proxy;




//这种方式是静态代理
public class Mytest {


	public static void main(String[] args) {
		
		//直接通过工厂,直接对象来获得
		LiLingFactory lf=new LiLingFactory();
		int product = lf.product();
		System.out.println(product+"最低格");
		
		//通过代理对象来获得值	
		LiLingStore store = new LiLingStore();
		int product2 = store.product();
		System.out.println(product2);
	}
}

动态代理

//定义一个房东和租房者相同的方法
public interface HousePrice {	
	public int price();
}

目标对象
package com.my.proxy01;

public class HouseOwer implements HousePrice{

	@Override
	public int price() {
		// TODO Auto-generated method stub
		int price=100;
		System.out.println("房价又涨了,房东又要涨房租了");
		return price;
		
	}

}





package com.my.proxy01;

import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
import java.lang.reflect.Proxy;

public class MyHouse {
	public static void main(String[] args) {
		/*
		 * loader是类加载器,通过反射来加载类
		 */
		
		//获取直接对象(目标对象)
		HouseOwer houseOwer = new HouseOwer();
		
		//获得类加载器
		ClassLoader houseOwerLoader = houseOwer.getClass().getClassLoader();
		//获得对象中接口方法的一个数组
		Class<?>[] houseOwerinterface = houseOwer.getClass().getInterfaces();
		
		//其实newProxyInstance方法相当于动态的创建了一个类,通过传类加载器,获取中间的接口,创建出来了一个动态代理的类
		HousePrice proxy = (HousePrice) Proxy.newProxyInstance(houseOwerLoader, houseOwerinterface, new InvocationHandler() {
			
			//new InvocationHandler()相当于是一个监听器来监听了直接对象
			
			/*
			 * proxy是获取当前直接对象
			 * method是获取直接对象中的方法
			 * args中的值
			 * 返回值:返回值就是代理对象代用方法的返回值
			 * 
			 * 
			 */
			@Override
			public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
				// TODO Auto-generated method stub
				Object invoke = method.invoke(houseOwer, args);
				System.out.println(method);
				System.out.println("我一定会调用的");
				return invoke;
			}
		});
		//调用代理对象的方法
		int price = proxy.price();
		System.out.println(price);
	}

}










动态代理中的原理,代码注释中已经讲的很清楚了,大家自己看看哈






  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值