-
Car?car?=?new?Car(); Class<?>?cls?=?car.getClass(); InvocationHandler?timeHandler?=?new?TimeHandler(car); Moveable?timeMoveable?=?(Moveable)?Proxy.newProxyInstance(cls.getClassLoader(),?cls.getInterfaces(),?timeHandler); InvocationHandler?logHandler?=?new?LogHandler(timeMoveable); Moveable?logMoveable?=?(Moveable)?Proxy.newProxyInstance(cls.getClassLoader(),?cls.getInterfaces(),?logHandler); logMoveable.move();
查看全部 -
代理模式:為其他對象提供一種代理,以控制對這個對象的訪問。
查看全部 -
@設(shè)計模式——代理模式——了解JDK動態(tài)代理 一、JDK動態(tài)代理 1、目的:動態(tài)產(chǎn)生代理,實現(xiàn)對【不同類】,【不同方法】的代理 2、java動態(tài)代理類,位于java.lang.reflect包下,一般涉及兩個類: (1)Interface InvocationHandler:該接口中僅定義了一個方法public object invoke(obj,method,args):實際使用中,obj指被代理類的對象,method指被代理的方法,args為該方法參數(shù)數(shù)組。這個抽象方法在代理類中動態(tài)實現(xiàn) (2)Proxy:該類即為動態(tài)代理類:static Object newProxyInstance(ClassLoader loader,Class[] interfaces,InvocationHandler h):返回代理類的一個實例,返回后的代理類可以被當(dāng)作代理類使用(可使用被代理類的在【接口中】聲明過的方法)。 · 第一個參數(shù)loader為被代理類的加載器,通過被代理類.getClass().getClassLoader()得到 · 第二個參數(shù)interfaces為被代理類實現(xiàn)的所有接口,同樣通過getClass().getInterface()得到 · 第三個參數(shù)handler就是自己實現(xiàn)的InvocationHandler的實現(xiàn)類的對象 3、***實現(xiàn): · 聲明一個代理h實現(xiàn)InvocationHandler接口,通過【構(gòu)造方法接受被代理類】,并實現(xiàn)invoke方法,添加業(yè)務(wù)邏輯(實現(xiàn)原有功能并添加額外功能) · 在測試類中,通過共同實現(xiàn)接口的實例獲得代理對象,并實現(xiàn)方法,如Interface1 i = (Interface1)Proxy.newProxyInstance(classLoader,classInterfaces,h); · 通過動態(tài)代理對象m,代用其方法i.fun();
查看全部 -
概念及分類:為其他對象提供一種代理以控制對這個對象的訪問。代理對象起到中介作用,可去掉功能服務(wù)或增加額外的服務(wù)。
代理模式的分類:
遠程代理:為不同地理的對象,提供局域網(wǎng)代表對象。
虛擬代理:根據(jù)需要將資源消耗很大的對象進行延遲,真正需要的時候進行創(chuàng)建。
保護代理:控制對一個物品的訪問權(quán)限。
智能引用代理:額外其他的服務(wù)
查看全部 -
動態(tài)代理 對另一個對象的引用查看全部
-
靜態(tài)代理:代理和被代理對象在代理之前是確定的.他們都實現(xiàn)相同的接口或者繼承相同的抽象類.?
靜態(tài)代理的兩種實現(xiàn)方式:
1.繼承方式
不建議使用,如果使用繼承則會造成代理類無限疊加下去
2.聚合方式
代理之間可以相互傳遞,互相組合,提高代理的復(fù)用性
查看全部 -
cglib 動態(tài)代理
查看全部 -
代理模式這種機制可以叫做AOP,在不改變原有代碼的基礎(chǔ)上,添加或者刪除某些方法 例如: 要調(diào)用某個jar包中某個類的方法,但是不能改變源碼,我們可以采用JDK的動態(tài)代理模式,在該方法的前后添加業(yè)務(wù)邏輯,如記錄日志,權(quán)限控制等
查看全部 -
完善動態(tài)代理實現(xiàn) 首先得到系統(tǒng)編譯器,通過編譯器得到文件管理者,以獲取文件,然后編譯器執(zhí)行編譯任務(wù),完成編譯之后,將class文件加載到類加載器中,通過構(gòu)造方法得到實例,然后調(diào)用newInstance()接收一個對象的實例并返回。 (1)拿到編譯器 JavaCompiler compiler = ToolProvider.getSystemJavaCompiler(); (2)文件管理者 StandardJavaFileManager fileMgr = Compiler.getStandardFileManager(null,null,null); (3)獲取文件 Iterable units = fileMgr.getJavaFileObjects(filename); (4)編譯任務(wù) CompilationTask t =compiler.getTask(null,fileMgr,null,null,null,units); (5)load到內(nèi)存 ClassLoader cl = ClassLoader.getSystemClassLoader(); Class c = cl.loadClass(”com.imooc.proxy.$Proxy0”); (6)通過代理對象的構(gòu)造器構(gòu)造實例,并返回代理對象 Constructor ctr = c.getConstructor(infce); return ctr.newInstance(new Car());
查看全部 -
動態(tài)代理實現(xiàn)思路 實現(xiàn)功能;通過Proxy的newProxyInstance返回代理對象 1.聲明一段源碼(動態(tài)產(chǎn)生代理) 2.編譯源碼(JDK Compiler API),產(chǎn)生新的類(代理類) 3.將這個類load到內(nèi)存當(dāng)中,產(chǎn)生一個新的對象(代理對象) 4.return 代理對象
查看全部 -
靜態(tài)代理:繼承、聚合 動態(tài)代理:JDK、cglib JDK動態(tài)代理:只能對實現(xiàn)了接口的類實現(xiàn)代理 ,沒有接口就不能實現(xiàn)JDK動態(tài)代理 CGLIB動態(tài)代理:針對類產(chǎn)生子類,通過方法攔截技術(shù)攔截所有的父類方法的調(diào)用
查看全部 -
@設(shè)計模式——代理模式——了解JDK動態(tài)代理 一、JDK動態(tài)代理 1、目的:動態(tài)產(chǎn)生代理,實現(xiàn)對【不同類】,【不同方法】的代理 2、java動態(tài)代理類,位于java.lang.reflect包下,一般涉及兩個類: (1)Interface InvocationHandler:該接口中僅定義了一個方法public object invoke(obj,method,args):實際使用中,obj指被代理類的對象,method指被代理的方法,args為該方法參數(shù)數(shù)組。這個抽象方法在代理類中動態(tài)實現(xiàn) (2)Proxy:該類即為動態(tài)代理類:static Object newProxyInstance(ClassLoader loader,Class[] interfaces,InvocationHandler h):返回代理類的一個實例,返回后的代理類可以被當(dāng)作代理類使用(可使用被代理類的在【接口中】聲明過的方法)。 · 第一個參數(shù)loader為被代理類的加載器,通過被代理類.getClass().getClassLoader()得到 · 第二個參數(shù)interfaces為被代理類實現(xiàn)的所有接口,同樣通過getClass().getInterface()得到 · 第三個參數(shù)handler就是自己實現(xiàn)的InvocationHandler的實現(xiàn)類的對象 3、***實現(xiàn): · 聲明一個代理h實現(xiàn)InvocationHandler接口,通過【構(gòu)造方法接受被代理類】,并實現(xiàn)invoke方法,添加業(yè)務(wù)邏輯(實現(xiàn)原有功能并添加額外功能) · 在測試類中,通過共同實現(xiàn)接口的實例獲得代理對象,并實現(xiàn)方法,如Interface1 i = (Interface1)Proxy.newProxyInstance(classLoader,classInterfaces,h); · 通過動態(tài)代理對象m,代用其方法i.fun();
查看全部 -
@設(shè)計模式——代理模式——靜態(tài)代理的實現(xiàn) 1、聚合代理優(yōu)于繼承代理。因為實現(xiàn)功能疊加的情況下,聚合代理通過相互代理可以實現(xiàn)功能重用,而繼承代理必須寫多個類來實現(xiàn)多功能疊加。 2、但靜態(tài)代理只能代理一種類型的被代理類,換個類型的就不行了,這需要動態(tài)代理
查看全部 -
一、靜態(tài)代理 1、靜態(tài)代理:代理和被代理對象在【代理之前】都是【確定】的。他們都實現(xiàn)【相同的接口或者繼承相同的抽象類】 2、代理實現(xiàn)方法: (1)繼承法:代理類直接【繼承】被代理類,實現(xiàn)其原有方法,并添加一些額外功能 (2)聚合方法:代理類實現(xiàn)【相同的功能接口:很重要,事項相同接口,不同代理也可以進行相互代理】,并在內(nèi)聲明一個被代理類的對象(類似封裝),通過內(nèi)部對象實現(xiàn)其原有方法,并添加額外功能
查看全部 -
代理模式 1、概念:為其他對象提供一種代理,以控制對這個對象的訪問(例如火車站代售處)。代理對象起到中介作用,可去掉功能服務(wù)或增加額外的服務(wù)。 2、分類:a、遠程代理---為不同地理的對象提供局域網(wǎng)代表對象。(類似于客戶端和服務(wù)器端) b、虛擬代理---根據(jù)需要將資源消耗很大的對象進行延遲,真正需要的時候才進行創(chuàng)建。(網(wǎng)頁中 圖片的加載,先用一張?zhí)摂M的圖片進行顯示,等圖片加載完成后再進行顯示) c 、保護代理---控制用戶的訪問權(quán)限。(發(fā)帖功能) d、智能應(yīng)用代理---提供對目標對象一些額外的服務(wù)。(火車站)
查看全部
舉報