本來第4個demo應(yīng)該是SPRing框架獲取自定義注解的類的實例對象列表。但是這篇文章已經(jīng)寫過,不再贅述,可以參考http://blog.csdn.net/mrbcy/article/details/54839463
因為接口的實現(xiàn)是在服務(wù)端的,因此客戶端沒有辦法直接拿到一個實現(xiàn)類的對象的,因此必須由框架提供一個動態(tài)代理。這個動態(tài)代理截獲客戶的調(diào)用請求,然后向服務(wù)器發(fā)起調(diào)用,最后將服務(wù)器的響應(yīng)發(fā)回給客戶代碼。代碼已經(jīng)上傳到http://download.csdn.net/detail/mrbcy/9748050
來看一下關(guān)鍵的代碼:
package tech.mrbcy.mrpc.demo.demo4;import java.lang.reflect.InvocationHandler;import java.lang.reflect.Method;import java.lang.reflect.Proxy;public class RpcProxy { @SuppressWarnings("unchecked") public<T> T createProxy(Class<T> interfaceClass){ return (T) Proxy.newProxyInstance(interfaceClass.getClassLoader(), new Class<?>[]{interfaceClass}, new InvocationHandler() { public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { System.out.println("方法已調(diào)用:" + method); // 下面可以連接服務(wù)器,發(fā)送調(diào)用請求,然后返回服務(wù)器的結(jié)果了 return null; } }); }}總體來講,代碼很簡單就是創(chuàng)建了一個動態(tài)代理對象。但是有一點需要指出。
Proxy.newProxyInstance(interfaceClass.getClassLoader(), new Class<?>[]{interfaceClass}, new InvocationHandler() { }這里的new Class<?>[]{interfaceClass}不能寫成interfaceClass.getInterfaces,因為調(diào)用方代碼傳入的是interface的Class對象,用它是獲取不到自己的。
到現(xiàn)在,整個項目的第一步算是完成了,下面就是整合這幾個Demo變成框架了。
這幾天在考科三,不一定什么時候更新了。
新聞熱點
疑難解答