java向上
『壹』 java中關於向上轉型的問題
RTTI機制
向上轉型的目的仍然是抽象。
比如
水果有顏色、味道。不同的水果有不同的顏色和味道。那麼當
水果
sg
=
new
橘子();
水果
sg1
=
new
蘋果();
sg.color();sg.taste();
sg1.color();sg1.taste();
sg,sg1都是水果實例的引用。但會調用不同的具體子類的方法。
其目地都是抽象。通過訪問父類或介面的方法(公共)達到一種對具體實現的封裝。對於介面的使用者來說,不需要關心實現細節。提高內聚,降低不必要的耦合。
再多說一句:注意轉型時帶來的
內存切片。
『貳』 java中的向上轉型向下轉型是甚麼意思該如何去理解!
下面是我個人看法,僅供參考向上轉型指子類向父類轉型或與父類型變數產生運算向下轉型指父類型向子類轉型舉個例子Objecto=newHashMap();//變數o定義的是Object類型,實際初始化時是HashMap類型(Object是所有類的父類),屬於向上轉型,沒有任何問題Strings=o.get(id);//會報錯//這條語句,從HashMap中獲得對象,賦值到String變數由於是原生的HashMap,所以裡面的元素是Object類型,賦值給String變數相當於向下轉型,有毛病,需要強迫類型轉換Strings=(String)o.get(id);//當前條件是HashMap中元素的確是String類型
『叄』 java向上造型有什麼作用為什麼要造型,有什麼效果
向上造型:父類的引用指向子類的對象。
向上造型可以大大提高程序的可擴展性。利於代碼維護。
面向對象的三大特性:封裝;繼承;多態。向上造型可以看做多態的一種體現。即允許一種類型有不同的實現(可以理解為事物存在的多種體現形態)。
典型應用:介面。
沒有什麼效果,只是是代碼精簡而已
『肆』 在java裡面的向上轉型和向下轉型的具體好處在哪裡
java裡面的向上轉型和向下轉型的具體好處如下:
1.轉型是在繼承的基礎上而言的,繼承是面向對象語言中,代碼復用的一種機制,通過繼承,子類可以復用父類的功能,如果父類不能滿足當前子類的需求,則子類可以重寫父類中的方法來加以擴展。
2.向上轉型:子類引用的對象轉換為父類類型稱為向上轉型。通俗地說就是是將子類對象轉為父類對象。此處父類對象可以是介面
向上轉型時,父類指向子類引用對象會遺失除與父類對象共有的其他方法,也就是在轉型過程中,子類的新有的方法都會遺失掉,在編譯時,系統會提供找不到方法的錯誤。實例如下:
publicclassAnimal{
publicvoideat(){
System.out.println("animaleatting...");
}
}
classBirdextendsAnimal{
publicvoideat(){
System.out.println("birdeatting...");
}
publicvoidfly(){
System.out.println("birdflying...");
}
}
classMain{
publicstaticvoidmain(String[]args){
Animalb=newBird();//向上轉型
b.eat();
b.fly();//此處提示在Animal中沒有定義fly方法。
}
『伍』 在java 中,什麼叫向上轉型
java 轉型問題其實並不復雜,只要記住一句話:父類引用指向子類對象。
什麼叫父類引用指向子類對象,且聽我慢慢道來.
從2個名詞開始說起:向上轉型(upcasting) 、向下轉型(downcasting).
舉個例子:有2個類,Father是父類,Son類繼承自Father。
Father f1 = new Son(); // 這就叫 upcasting (向上轉型)
// 現在f1引用指向一個Son對象
Son s1 = (Son)f1; // 這就叫 downcasting (向下轉型)
// 現在f1還是指向Son對象
第2個例子:
Father f2 = new Father();
Son s2 = (Son)f2; // 出錯,子類引用不能指向父類對象
你或許會問,第1個例子中:Son s1 = (Son)f1;問什麼 是正確的呢。
很簡單因為f1指向一個子類對象,Father f1 = new Son(); 子類s1引用當然可以指向子類對象了。
而f2 被傳給了一個Father對象,Father f2 = new Father();子類s1引用不能指向父類對象。
總結:
1。父類引用指向子類對象,而子類引用不能指向父類對象。
2。把子類對象直接賦給父類引用叫upcasting向上轉型,向上轉型不用強制轉換。
如:Father f1 = new Son();
3。把指向子類對象的父類引用賦給子類引用叫向下轉型(downcasting),要強制轉換。
如:f1 就是一個指向子類對象的父類引用。把f1賦給子類引用s1即 Son s1 = (Son)f1;
其中f1前面的(Son)必須加上,進行強制轉換。
一、向上轉型。
通俗地講即是將子類對象轉為父類對象。此處父類對象可以是介面。
1,向上轉型中的方法調用。
看下面代碼:
[java] view plainprint?
package com.wensefu.others;
public class Animal {
public void eat(){
System.out.println("animal eatting...");
}
}
class Bird extends Animal{
public void eat(){
System.out.println("bird eatting...");
}
public void fly(){
System.out.println("bird flying...");
}
}
class Main{
public static void main(String[] args) {
Animal b=new Bird(); //向上轉型
b.eat();
//! error: b.fly(); b雖指向子類對象,但此時丟失fly()方法
dosleep(new Male());
dosleep(new Female());
}
public static void dosleep(Human h) {
h.sleep();
}
}
[java] view plainprint?
package com.wensefu.others;
public class Human {
public void sleep() {
System.out.println("Human sleep..");
}
}
class Male extends Human {
@Override
public void sleep() {
System.out.println("Male sleep..");
}
}
class Female extends Human {
@Override
public void sleep() {
System.out.println("Female sleep..");
}
}
注意這里的向上轉型:
Animal b=new Bird(); //向上轉型
b.eat();
此處將調用子類的eat()方法。原因:b實際指向的是Bird子類,故調用時會調用子類本身的方法。
需要注意的是向上轉型時b會遺失除與父類對象共有的其他方法。如本例中的fly方法不再為b所有。
2,向上轉型的好處。
看上面的代碼,
public static void dosleep(Human h) {
h.sleep();
}
這里以父類為參數,調有時用子類作為參數,就是利用了向上轉型。這樣使代碼變得簡潔。不然的話,
如果dosleep以子類對象為參數,則有多少個子類就需要寫多少個函數。這也體現了JAVA的抽象編程思想。
二、向下轉型。
與向上轉型相反,即是把父類對象轉為子類對象。
看下面代碼:
[java] view plainprint?
package com.wensefu.other1;
public class Girl {
public void smile(){
System.out.println("girl smile()...");
}
}
class MMGirl extends Girl{
@Override
public void smile() {
System.out.println("MMirl smile sounds sweet...");
}
public void c(){
System.out.println("MMirl c()...");
}
}
class Main{
public static void main(String[] args) {
Girl g1=new MMGirl(); //向上轉型
g1.smile();
MMGirl mmg=(MMGirl)g1; //向下轉型,編譯和運行皆不會出錯
mmg.smile();
mmg.c();
Girl g2=new Girl();
// MMGirl mmg1=(MMGirl)g2; //不安全的向下轉型,編譯無錯但會運行會出錯
// mmg1.smile();
// mmg1.c();
/*output:
* CGirl smile sounds sweet...
* CGirl smile sounds sweet...
* CGirl c()...
* Exception in thread "main" java.lang.ClassCastException: com.wensefu.other1.Girl
* at com.wensefu.other1.Main.main(Girl.java:36)
*/
if(g2 instanceof MMGirl){
MMGirl mmg1=(MMGirl)g2;
mmg1.smile();
mmg1.c();
}
}
}
Girl g1=new MMGirl(); //向上轉型
g1.smile();
MMGirl mmg=(MMGirl)g1; //向下轉型,編譯和運行皆不會出錯
這里的向下轉型是安全的。因為g1指向的是子類對象。
而
Girl g2=new Girl();
MMGirl mmg1=(MMGirl)g2; //不安全的向下轉型,編譯無錯但會運行會出錯
運行出錯:
Exception in thread "main" java.lang.ClassCastException: com.wensefu.other1.Girl
at com.wensefu.other1.Main.main(Girl.java:36)
如代碼所示,可以通過instanceof來防止出現異常。