本文目錄一覽:
- 1、java靜態代理與動態代理的區別
- 2、在學習JAVA過程遇到的一些基礎性疑惑,求解惑!
- 3、關於JAVA多態(動態綁定)的一點小疑惑???
- 4、求大神詳細並用白話文解答JAVA中的疑惑
- 5、java動態代理的疑惑
java靜態代理與動態代理的區別
JAVA的靜態代理與動態代理比較
1.靜態代理類:
由程序員創建或由特定工具自動生成源代碼,再對其編譯。在程序運行前,代理類的.class文件就已經存在了。動態代理類:在程序運行時,運用反射機制動態創建而成。
由此可見,代理類可以為委託類預處理消息、把消息轉發給委託類和事後處理消息等。
例程1 HelloService.java
package proxy;
import java.util.Date;
public interface HelloService{
public String echo(String msg);
public Date getTime();
}
2.動態代理類
與靜態代理類對照的是動態代理類,動態代理類的字節碼在程序運行時由Java反射機制動態生成,無需程序員手工編寫它的源代碼。動態代理類不僅簡化了編程工作,而且提高了軟件系統的可擴展性,因為Java 反射機制可以生成任意類型的動態代理類。java.lang.reflect 包中的Proxy類和InvocationHandler 接口提供了生成動態代理類的能力。
Proxy類提供了創建動態代理類及其實例的靜態方法。
(1)getProxyClass()靜態方法負責創建動態代理類,它的完整定義如下:
public static Class? getProxyClass(ClassLoader loader, Class?[] interfaces) throws IllegalArgumentException
參數loader 指定動態代理類的類加載器,參數interfaces 指定動態代理類需要實現的所有接口。
(2)newProxyInstance()靜態方法負責創建動態代理類的實例,它的完整定義如下:
public static Object newProxyInstance(ClassLoader loader, Class?[] interfaces, InvocationHandler handler) throws
IllegalArgumentException
參數loader 指定動態代理類的類加載器,參數interfaces 指定動態代理類需要實現的所有接口,參數handler 指定與動態代理類關聯的 InvocationHandler 對象。
以下兩種方式都創建了實現Foo接口的動態代理類的實例:
/**** 方式一 ****/
//創建InvocationHandler對象
InvocationHandler handler = new MyInvocationHandler(…);
//創建動態代理類
Class proxyClass = Proxy.getProxyClass(Foo.class.getClassLoader(), new Class[] { Foo.class });
//創建動態代理類的實例
Foo foo = (Foo) proxyClass.getConstructor(new Class[] { InvocationHandler.class }).
newInstance(new Object[] { handler });
/**** 方式二 ****/
//創建InvocationHandler對象
InvocationHandler handler = new MyInvocationHandler(…);
//直接創建動態代理類的實例
Foo foo = (Foo) Proxy.newProxyInstance(Foo.class.getClassLoader(),new Class[] { Foo.class }, handler);
由Proxy類的靜態方法創建的動態代理類具有以下特點:
動態代理類是public、final和非抽象類型的;
動態代理類繼承了java.lang.reflect.Proxy類;
動態代理類的名字以“$Proxy”開頭;
動態代理類實現getProxyClass()和newProxyInstance()方法中參數interfaces指定的所有接口;
在學習JAVA過程遇到的一些基礎性疑惑,求解惑!
final修飾的類,不可以被繼承,沒有子類。
fianl修飾的方法,不可以被重寫。
fianl修飾的屬性,值不可以修改。
?extends Object 是泛型中的特別寫法, 這個的意思是 object的子類。 ?繼承與object,只要是object的子類都可以。
你說的+號,java中沒有符號的重載,這個和c/c++不一樣。 +號用於字符串,是連接字符串用的。基本類型+“” 結果就是字符串。 system。out。println()或print()輸出的是字符串
關於JAVA多態(動態綁定)的一點小疑惑???
Peron p = new Stu();
必須保證你的子類裡面的方法是重寫了父類的方法,這樣才可以調用。如果是子類獨有的方法是不能調的。如果要調子類獨有的方法有兩種方式,Stu stu = new Stu();或者你上邊的那種實例化後再向下轉型。
求大神詳細並用白話文解答JAVA中的疑惑
放在Sysconstants.java中是因為應用中可能有多個地方會用到這個屬性。Sysconstants可以集中管理這些屬性。比如如果你不這樣做,那可能有這樣的情況:
public void foo() {
doAction(“LOGIN”);
// do something
}
public void foo() {
doAction(“LOGIN”);
// do something
}
這樣是不利於維護的,因為如果以後”LOGIN”比如需要變成”登錄”,那麼代碼就需要變成下面這樣的了:
public void foo() {
doAction(“登錄”);
// do something
}
public void foo() {
doAction(“登錄”);
// do something
}
兩個地方都要修改,而且這樣很容易遺漏修改某些地方(比如同時有10個地方都用到這個)。而如果統一配置在Sysconstants.java中:
1、首先這個類的名字就告訴你這個類維護的是一些全局系統常量
2、你把”LOGIN”配在這裡,將來即使要修改”LOGIN”為“登錄”時,你也只需要改這裡一個地方,其他地方都維持類似下面這樣不變:
public void foo() {
doAction(Sysconstants.SYS_LOGIN);
// do something
}
public void foo() {
doAction(Sysconstants.SYS_LOGIN);
// do something
}
3、你只需要查看Sysconstants.java類就可以大概知道應用有哪些屬性是可以配置的
總的一句話:這樣做可以提高代碼可維護性和配置方便性。
java動態代理的疑惑
java.lang.reflect.Proxy
public static Object newProxyInstance(ClassLoader loader,
Class?[] interfaces, InvocationHandler h)
你傳遞的參數 Class?[] interfaces
遍歷它,對每個 interfacesClass 調用 getMethods() 獲得 Method[]
就得到了要指定的所有方法了。
【明白了嗎】
【好好學,努力啊,年輕有為】
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/270798.html