第一章 认识SSM框架和Redis
1.1 Spring框架
Sring理念
Ioc 控制反转 IOC是一个容器,在Spring中,它会认为一切Java资源都是JavaBean,容器的目标是管理Bean和它们之间的关系。
Aop 面向切面编程
第二章 Java设计模式
2.1 java 反射技术
Java反射技术 可以配置:类的全限定名、方法和参数,完成对象的初始化,甚至是反射某些方法。
在Java中反射是通过包java.lang.reflect.*实现的。
2.1.1通过反射构建对象
public class ReflectTmp{
public ReflectTmp(){};
public ReflectTmp(Srting str){};
public void sayHello(Srting str){};
}
/* 通过反射获取对象*/
public ReflectTmp getInstance()
{
try {
object =(ReflectTmp)Class.forName("com.xxx.ReflectTmp").getConstructor(String.class).newInstance("123");
} catch (InstantiationException | IllegalAccessException | IllegalArgumentException | InvocationTargetException
| NoSuchMethodException | SecurityException | ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return object;
}
2.1.2 反射方法
public static Object reflectMethod()
{
Object returnobj = null;
ReflectTmpobj1 = newReflectTmp("456");
try {
Method method =ReflectTmp.class.getMethod("sayHello", String.class);
returnobj = method.invoke(obj1, "hello World !");
} catch (IllegalAccessException | IllegalArgumentException | InvocationTargetException | NoSuchMethodException | SecurityException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return returnobj;
}
2.2 动态代理和责任链模式
动态代理的意义在于生成一个占位(又称为代理对象),来代理真实对象,从而控制真实对象的访问。
代理分为两个步骤:
-
代理对象与真实对象建立代理关系
-
实现代理对象的代理逻辑方法
2.2.1 JDK动态代理
JDK动态代理是由java.lang.reflect.*包提供的方式,它必须借助一个借接口才能产生代理对象,所以先定义接口。
其次,在JDK动态代理中,要实现代理逻辑类必须去实现java.lang.reflect.InvocationHandler接口,它定义了一个invoke方法,并提供接口数组用于下挂代理对象。
第一步 建立代理对象与真实对象的关系
Procx.newProxyInstance(target.getClass().getClassLoader(),target.getClass().getInterfaces(), this);
newProxyInstance包含三个参数
第一个:类加载器
第二个:把生成的代理对象挂在哪些接口下
第三个:定义实现方法逻辑的代理类。
第二步 实现代理的逻辑方法
public Object invoke(Object proxy, Method method, Object[]args) throws Throwable{}
invoke方法可以实现代理逻辑
三个参数依次为:
proxy 代理对象
method 当前调度的方法
args 调度方法的参数
2.2.2 CGLIB动态代理
CGFLIB动态代理优势在于不用定义接口,只要一个非抽象类就能实现动态代理。
第一步 生成CGLIB代理对象
使用CGLIB的加强者Enhancer,通过设置超类的方式(setSuperclass),然后通过setCallback方法设置哪个类为它的代理类。被设为代理类的对象必须实现接口MethodInterceptor的方法intercept。
第二步实现代理逻辑
public Object intercept(Object proxy, Method method, Object[]args, MethodProxy methodProxy)throws Throwable{
/* CGLIB反射调用真实对象方法*/
Object obj = methodProxy.invokeSuper(proxy, args);
return obj;
}
2.2.3 拦截器
定义拦截器接口
public interface Interceptor{
public boolean before(Object proxy, Object target, Method method, Object [] args);
public boolean around(Object proxy, Object target, Method method, Object [] args);
public boolean after(Object proxy, Object target, Method method, Object [] args);
}
3个方法的参数依次为:proxy代理对象,target真实对象,method方法,args运行方法的参数。
before方法返回boolean值,它在真实对象前调度。当返回true,则反射真实对象的方法,返回false,则调用around方法。
在反射真实对象方法或者around方法执行后,执行after方法。
拦截器对象在代理对象创建时同时创建,拦截器对象的方法 在代理对象的逻辑处理方法中调用。
2.2.4 责任链模式
当一个对象在一条链上被多个拦截器处理时,我们把这样的设计模式成为责任链模式,它用于一个对象在多个角色中传递的场景。可以使用层层代理的的方式来实现。
public interface HelloWorld{
public void sayHello(String str);
}
public interface HelloWorldImpl implements HelloWorld{
public void sayHello(String str)
{
/* xxx*/
}
}
public static void main(String []args)
{
HelloWorld proxy1 = (HelloWorld)InterceptorJDKProxy(new HelloWorldImpl(),“com.xxx.Interceptor1”);
HelloWorld proxy2 = (HelloWorld)InterceptorJDKProxy(proxy1,“com.xxx.Interceptor2");
HelloWorld proxy3 = (HelloWorld)InterceptorJDKProxy(proxy2,“com.xxx.Interceptor3");
proxy3.sayHello("hello");
}
结果:
【拦截器3的】的before方法执行
【拦截器2的】的before方法执行
【拦截器1的】的before方法执行
hello
【拦截器1的】的after方法执行
【拦截器2的】的after方法执行
【拦截器3的】的after方法执行
before方法按照从最后一个拦截器到第一个拦截器的加载顺序执行,after按照从第一个拦截器到最后一个拦截器的加载顺序执行。
2.3 观察者模式
观察者模式又称为发布订阅模式,是对象的行为模式。观察者模式定义了一种一对多的依赖关系,让多个观察者同时监视着被观察者,当观察者发生变化的时候,通知所有观察者,并让其自动更新自己。
第一步 定义被观察者
首先继承java.util.Observable类
观察者的方法:
/* 添加观察者*/
addObserver(Observer observer);
/* 告知观察者 被观察者发生了改变,如果没有,则无法触发其行为*/
setChanged();
/* 告知观察者,让他们发生相应的动作,并将参数传递给观察者*/
notifyObservers(object obj);
第二步 定义观察者
观察者要实现 java.util.Observer接口的update()方法
2.4 工厂模式和抽象工厂模式
2.5 创建者模式
创建者模式属于对象的创建模式。可以将一个产品的属性与产品的生成过程分开,从而使一个建造过程中生成具有不同属性的产品对象。