1.IO
字节流和字符流。装饰者模式构建多种流。
关闭流时只需要关闭最外层的流。字节流和字符流之间的转换: InputStreamReader需要和InputStream套接;OutputStreamWriter需要和OutputStream套接。2.反射机制
java的反射机制允许程序在运行时加载、探知、使用编译期间完全未知的class。可以实现动态创建对象和编译即运行时确定类型,绑定对象。在jdk的动态代理中有具体使用。
3.JDK的动态代理
jdk的动态代理模式,动态代理是指在运行时,动态生成代理类。代理类的字节码将在运行时生成并载入当前的ClassLoader。JDK动态代理不能对类进行代理,只能对接口进行代理。代理类和实现类实现相同接口。spring中使用到了jdk的动态代理。
步骤:
1)通过实现InvocationHandler接口创建自己的调用处理器
2)通过为Proxy类指定ClassLoader对象和一组interface来创建动态代理类
3)通过反射机制获得动态代理类的构造函数,其唯一参数类型是调用处理器接口类型
4)通过构造函数创建动态代理类实例,构造时调用处理器对象作为参数被传入
//InvocationHandlerImpl 实现了InvocationHandler接口,并能实现方法调用从代理类到委托类的分派转发
//其内部通常包含指向委托类实例的引用,用于真正执行分派转发过来的方法调用
InvocationHandler handler = newInvocationHandlerImpl(..);
//通过Proxy为包括Interface接口在内的一组接口动态创建代理类的对象
Class class = Proxy.getProxyClass(classLoader,newClass[]{Interface.class,...});
//通过反射从生成的类对象获得构造函数对象
Constructor constructor = class.getConstructor(newClass[]{InvocationHandler.class});
//通过构造函数对象创建动态代理类实例
Interface Proxy = (Interface)constructor.newInstance(newObject[]{handler});
//Proxy类的静态方法newProxyInstance对上面具体步骤的后三步做了封装,简化了动态代理对象的获取过程。
//InvocationHandlerImpl实现了InvocaitonHandler接口,并能实现方法调用从代理类到委托类的分派转发
InvocaitonHandler handler = newInvocationHandlerImpl(..);
//通过Proxy直接创建动态代理类实例
Interface proxy = (Interface)Proxy.newProxyInstance(classLoader,newClass[]{Interface.class},handler);