freepeople性欧美熟妇, 色戒完整版无删减158分钟hd, 无码精品国产vα在线观看DVD, 丰满少妇伦精品无码专区在线观看,艾栗栗与纹身男宾馆3p50分钟,国产AV片在线观看,黑人与美女高潮,18岁女RAPPERDISSSUBS,国产手机在机看影片

正文內(nèi)容

java各知識點詳細(xì)總結(jié)(超級經(jīng)典)(編輯修改稿)

2025-08-31 22:54 本頁面
 

【文章內(nèi)容簡介】 ():是在調(diào)用父類中空參數(shù)的構(gòu)造方法。為什么子類對象初始化時,都需要調(diào)用父類中的方法?(為什么要在子類構(gòu)造方法的第一行加入這個super()?)因為子類繼承父類,會繼承到父類中的數(shù)據(jù),所以必須要看父類是如何對自己的數(shù)據(jù)進(jìn)行初始化的。所以子類在進(jìn)行對象初始化時,先調(diào)用父類的構(gòu)造方法,這就是子類的實例化過程。注意:子類中所有的構(gòu)造方法都會默認(rèn)訪問父類中的空參數(shù)的構(gòu)造方法,因為每一個子類構(gòu)造內(nèi)第一行都有默認(rèn)的語句super()。 如果父類中沒有空參數(shù)的構(gòu)造方法,那么子類的構(gòu)造方法內(nèi),必須通過super語句指定要訪問的父類中的構(gòu)造方法。如果子類構(gòu)造方法中用this來指定調(diào)用子類自己的構(gòu)造方法,那么被調(diào)用的構(gòu)造方法也一樣會訪問父類中的構(gòu)造方法。問題:super()和this()是否可以同時出現(xiàn)的構(gòu)造方法中。兩個語句只能有一個定義在第一行,所以只能出現(xiàn)其中一個。super()或者this():為什么一定要定義在第一行?因為super()或者this()都是調(diào)用構(gòu)造方法,構(gòu)造方法用于初始化,所以初始化的動作要先完成。繼承的細(xì)節(jié):什么時候使用繼承呢?當(dāng)類與類之間存在著所屬關(guān)系時,才具備了繼承的前提。a是b中的一種。a繼承b。狼是犬科中的一種。英文書中,所屬關(guān)系: is a 注意:不要僅僅為了獲取其他類中的已有成員進(jìn)行繼承。所以判斷所屬關(guān)系,可以簡單看,如果繼承后,被繼承的類中的功能,都可以被該子類所具備,那么繼承成立。如果不是,不可以繼承。細(xì)節(jié)二:在方法覆蓋時,注意兩點:1:子類覆蓋父類時,必須要保證,子類方法的權(quán)限必須大于等于父類方法權(quán)限可以實現(xiàn)繼承。否則,編譯失敗。2:覆蓋時,要么都靜態(tài),要么都不靜態(tài)。 (靜態(tài)只能覆蓋靜態(tài),或者被靜態(tài)覆蓋)繼承的一個弊端:打破了封裝性。對于一些類,或者類中功能,是需要被繼承,或者復(fù)寫的。這時如何解決問題呢?介紹一個關(guān)鍵字,final:最終。final特點:1:這個關(guān)鍵字是一個修飾符,可以修飾類,方法,變量。2:被final修飾的類是一個最終類,不可以被繼承。3:被final修飾的方法是一個最終方法,不可以被覆蓋。4:被final修飾的變量是一個常量,只能賦值一次。 其實這樣的原因的就是給一些固定的數(shù)據(jù)起個閱讀性較強的名稱。 不加final修飾不是也可以使用嗎?那么這個值是一個變量,是可以更改的。加了final,程序更為嚴(yán)謹(jǐn)。常量名稱定義時,有規(guī)范,所有字母都大寫,如果由多個單詞組成,中間用 _ 連接。抽象類: abstract抽象:不具體,看不明白。抽象類表象體現(xiàn)。在不斷抽取過程中,將共性內(nèi)容中的方法聲明抽取,但是方法不一樣,沒有抽取,這時抽取到的方法,并不具體,需要被指定關(guān)鍵字abstract所標(biāo)示,聲明為抽象方法。抽象方法所在類一定要標(biāo)示為抽象類,也就是說該類需要被abstract關(guān)鍵字所修飾。抽象類的特點:1:抽象方法只能定義在抽象類中,抽象類和抽象方法必須由abstract關(guān)鍵字修飾(可以描述類和方法,不可以描述變量)。2:抽象方法只定義方法聲明,并不定義方法實現(xiàn)。3:抽象類不可以被創(chuàng)建對象(實例化)。4:只有通過子類繼承抽象類并覆蓋了抽象類中的所有抽象方法后,該子類才可以實例化。否則,該子類還是一個抽象類。抽象類的細(xì)節(jié):1:抽象類中是否有構(gòu)造方法?有,用于給子類對象進(jìn)行初始化。2:抽象類中是否可以定義非抽象方法? 可以。其實,抽象類和一般類沒有太大的區(qū)別,都是在描述事物,只不過抽象類在描述事物時,有些功能不具體。所以抽象類和一般類在定義上,都是需要定義屬性和行為的。只不過,比一般類多了一個抽象方法。而且比一般類少了一個創(chuàng)建對象的部分。3:抽象關(guān)鍵字abstract和哪些不可以共存?final , private , static 4:抽象類中可不可以不定義抽象方法?可以。抽象方法目的僅僅為了不讓該類創(chuàng)建對象。模板方法設(shè)計模式:解決的問題:當(dāng)功能內(nèi)部一部分實現(xiàn)時確定,一部分實現(xiàn)是不確定的。這時可以把不確定的部分暴露出去,讓子類去實現(xiàn)。abstract class GetTime{ public final void getTime(){ //此功能如果不需要復(fù)寫,可加final限定 long start = ()。 code()。 //不確定的功能部分,提取出來,通過抽象方法實現(xiàn) long end = ()。 (毫秒是:+(endstart))。 } public abstract void code()。 //抽象不確定的功能,讓子類復(fù)寫實現(xiàn)}class SubDemo extends GetTime{ public void code(){ //子類復(fù)寫功能方法 for(int y=0。 y1000。 y++){ (y)。 } }}接 口:★★★★★1:是用關(guān)鍵字interface定義的。2:接口中包含的成員,最常見的有全局常量、抽象方法。注意:接口中的成員都有固定的修飾符。 成員變量:public static final 成員方法:public abstract interface Inter{ public static final int x = 3。 public abstract void show()。}3:接口中有抽象方法,說明接口不可以實例化。接口的子類必須實現(xiàn)了接口中所有的抽象方法后,該子類才可以實例化。否則,該子類還是一個抽象類。4:類與類之間存在著繼承關(guān)系,類與接口中間存在的是實現(xiàn)關(guān)系。 繼承用extends ;實現(xiàn)用implements ;5:接口和類不一樣的地方,就是,接口可以被多實現(xiàn),這就是多繼承改良后的結(jié)果。java將多繼承機(jī)制通過多現(xiàn)實來體現(xiàn)。 6:一個類在繼承另一個類的同時,還可以實現(xiàn)多個接口。所以接口的出現(xiàn)避免了單繼承的局限性。還可以將類進(jìn)行功能的擴(kuò)展。7:其實java中是有多繼承的。接口與接口之間存在著繼承關(guān)系,接口可以多繼承接口。接口都用于設(shè)計上,設(shè)計上的特點:(可以理解主板上提供的接口)1:接口是對外提供的規(guī)則。2:接口是功能的擴(kuò)展。3:接口的出現(xiàn)降低了耦合性。抽象類與接口:抽象類:一般用于描述一個體系單元,將一組共性內(nèi)容進(jìn)行抽取,特點:可以在類中定義抽象內(nèi)容讓子類實現(xiàn),可以定義非抽象內(nèi)容讓子類直接使用。它里面定義的都是一些體系中的基本內(nèi)容。接口:一般用于定義對象的擴(kuò)展功能,是在繼承之外還需這個對象具備的一些功能。抽象類和接口的共性:都是不斷向上抽取的結(jié)果。抽象類和接口的區(qū)別:1:抽象類只能被繼承,而且只能單繼承。接口需要被實現(xiàn),而且可以多實現(xiàn)。 2:抽象類中可以定義非抽象方法,子類可以直接繼承使用。接口中都是抽象方法,需要子類去實現(xiàn)。3:抽象類使用的是 is a 關(guān)系。接口使用的 like a 關(guān)系。 4:抽象類的成員修飾符可以自定義。接口中的成員修飾符是固定的。全都是public的。在開發(fā)之前,先定義規(guī)則,A和B分別開發(fā),A負(fù)責(zé)實現(xiàn)這個規(guī)則,B負(fù)責(zé)使用這個規(guī)則。至于A是如何對規(guī)則具體實現(xiàn)的,B是不需要知道的。這樣這個接口的出現(xiàn)就降低了A和B直接耦合性。 多 態(tài)★★★★★(面向?qū)ο筇卣髦唬悍椒ū旧砭途邆涠鄳B(tài)性,某一種事物有不同的具體的體現(xiàn)。體現(xiàn):父類引用或者接口的引用指向了自己的子類對象。//Animal a = new Cat()。父類可以調(diào)用子類中覆寫過的(父類中有的方法)多態(tài)的好處:提高了程序的擴(kuò)展性。繼承的父類或接口一般是類庫中的東西,(如果要修改某個方法的具體實現(xiàn)方式)只有通過子類去覆寫要改變的某一個方法,這樣在通過將父類的應(yīng)用指向子類的實例去調(diào)用覆寫過的方法就行了!多態(tài)的弊端:當(dāng)父類引用指向子類對象時,雖然提高了擴(kuò)展性,但是只能訪問父類中具備的方法,不可以訪問子類中特有的方法。(前期不能使用后期產(chǎn)生的功能,即訪問的局限性)多態(tài)的前提: 1:必須要有關(guān)系,比如繼承、或者實現(xiàn)。 2:通常會有覆蓋操作。多態(tài)的出現(xiàn)思想上也做著變化:以前是創(chuàng)建對象并指揮對象做事情。有了多態(tài)以后,我們可以找到對象的共性類型,直接操作共性類型做事情即可,這樣可以指揮一批對象做事情,即通過操作父類或接口實現(xiàn)。class 畢姥爺{ void 講課(){ (企業(yè)管理)。 } void 釣魚(){ (釣魚)。 }}class 畢老師 extends 畢姥爺{ void 講課(){ (JAVA)。 } void 看電影(){ (看電影)。 }}class { public static void main(String[] args) { 畢姥爺 x = new 畢老師()。 //畢老師對象被提升為了畢姥爺類型。 // ()。// ()。 //錯誤. 畢老師 y = (畢老師)x。 //將畢姥爺類型強制轉(zhuǎn)換成畢老師類型。 ()。//在多態(tài)中,自始自終都是子類對象在做著類型的變化。 }}如果想用子類對象的特有方法,如何判斷對象是哪個具體的子類類型呢?可以可以通過一個關(guān)鍵字 instanceof 。//判斷對象是否實現(xiàn)了指定的接口或繼承了指定的類格式:對象 instanceof 類型 ,判斷一個對象是否所屬于指定的類型。Student instanceof Person = true。//student繼承了person類*****多態(tài)在子父類中的成員上的體現(xiàn)的特點:1,成員變量:在多態(tài)中,子父類成員變量同名。 在編譯時期:參考的是引用型變量所屬的類中是否有調(diào)用的成員。(編譯時不產(chǎn)生對象,只檢查語法錯誤) 運行時期:也是參考引用型變量所屬的類中是否有調(diào)用的成員。 簡單一句話:無論編譯和運行,成員變量參考的都是引用變量所屬的類中的成員變量。 再說的更容易記憶一些:成員變量 編譯運行都看 = 左邊。2,成員方法。 編譯時期:參考引用型變量所屬的類中是否有調(diào)用的方法。 運行事情:參考的是對象所屬的類中是否有調(diào)用的方法。 為什么是這樣的呢?因為在子父類中,對于一模一樣的成員方法,有一個特性:覆蓋。 簡單一句:成員方法,編譯看引用型變量所屬的類,運行看對象所屬的類。 更簡單:成員方法 編譯看 = 左邊,運行看 = 右邊。3,靜態(tài)方法。 編譯時期:參考的是引用型變量所屬的類中是否有調(diào)用的成員。 運行時期:也是參考引用型變量所屬的類中是否有調(diào)用的成員。 為什么是這樣的呢?因為靜態(tài)方法,其實不所屬于對象,而是所屬于該方法所在的類。 調(diào)用靜態(tài)的方法引用是哪個類的引用調(diào)用的就是哪個類中的靜態(tài)方法。 簡單說:靜態(tài)方法 編譯運行都看 = 左邊。Object:所有類的直接或者間接父類,Java認(rèn)為所有的對象都具備一些基本的共性內(nèi)容,這些內(nèi)容可以不斷的向上抽取,最終就抽取到了一個最頂層的類中的,該類中定義的就是所有對象都具備的功能。具體方法:1,boolean equals(Object obj):用于比較兩個對象是否相等,其實內(nèi)部比較的就是兩個對象地址。如果根據(jù) equals(Object) 方法,兩個對象是相等的,那么對這兩個對象中的每個對象調(diào)用 hashCode 方法都必須生成相同的整數(shù)結(jié)果。而根據(jù)對象的屬性不同,判斷對象是否相同的具體內(nèi)容也不一樣。所以在定義類時,一般都會復(fù)寫equals方法,建立本類特有的判斷對象是否相同的依據(jù)。 public boolean equals(Object obj){ if(!(obj instanceof Person)) return false。 Person p = (Person)obj。 return == 。 }2,String toString():將對象變成字符串;默認(rèn)返回的格式:類名@哈希值 = getClass().getName() + 39。@39。 + (hashCode()) 為了對象對應(yīng)的字符串內(nèi)容有意義,可以通過復(fù)寫,建立該類對象自己特有的字符串表現(xiàn)形式。 public String toString(){ return person : +age。 }3,Class getClass():獲取任意對象運行時的所屬字節(jié)碼文件對象。4,int hashCode():返回該對象的哈希碼值。支持此方法是為了提高哈希表的性能。將該對象的內(nèi)部地址轉(zhuǎn)換成一個整數(shù)來實現(xiàn)的。通常equals,toString,hashCode
點擊復(fù)制文檔內(nèi)容
環(huán)評公示相關(guān)推薦
文庫吧 www.dybbs8.com
備案圖片鄂ICP備17016276號-1