2023年java各知識點詳細(xì)總結(jié)_第1頁
2023年java各知識點詳細(xì)總結(jié)_第2頁
2023年java各知識點詳細(xì)總結(jié)_第3頁
2023年java各知識點詳細(xì)總結(jié)_第4頁
2023年java各知識點詳細(xì)總結(jié)_第5頁
已閱讀5頁,還剩101頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

Java基礎(chǔ)知識總結(jié)

寫代碼:

1,明確需求。我要做什么?

2,分析思緒。我要怎么做?1,2,3O

3,擬定環(huán)節(jié)。每一個思緒部分用到哪些語句,方法,和對象。

4,代碼實現(xiàn)。用品體的java語言代碼把思緒體現(xiàn)出來。

學(xué)習(xí)新技術(shù)的四點:

1,該技術(shù)是什么?

2,該技術(shù)有什么特點(使用注意):

3,該技術(shù)怎么使用。demo

4,該技術(shù)什么時候用?testo

-:java概述:

1991年Sun公司的JamesGosling等人開始開發(fā)名稱為Oak的語言,希望用于控制嵌

入在有線電視互換盒、PDA等的微解決器;

1994年將Oak語言更名為Java;

Java的三種技術(shù)架構(gòu):

JAVAEE:JavaPlatformEnterpriseEdition,開發(fā)公司環(huán)境下的應(yīng)用程序,重要針對

web程序開發(fā);

JAVASE:JavaPlatformStandaidEdition,完畢桌面應(yīng)用程序的開發(fā),是其它兩

者的基礎(chǔ);

JAVAME:JavaP1atformMicroEdition,開發(fā)電子消費(fèi)產(chǎn)品和嵌入式設(shè)備,如手機(jī)中的

程序;

1,JDK:JavaDeve1opmentKit,java的開發(fā)和運(yùn)營環(huán)境,java的開發(fā)工具和jre。

2,JRE:JavaRuntimeEnvironment,java程序的運(yùn)營環(huán)境,java運(yùn)營的所需的類庫

+jVM(java虛擬機(jī))。

3,配置環(huán)境變量:讓javajdk\bin目錄下的工具,可以在任意目錄下運(yùn)營,因素是,將該工具所

在目錄告訴了系統(tǒng),當(dāng)使用該工具時,由指定的目錄。

環(huán)境變量的配置:

1):永久配置方式:JAVA_HOME=%安裝途徑外\Java\jdk

path=%JAVA_HOME%\bin

2):臨時配置方式:setpath=%path%;C:\ProgramFiles\Java\jdk\bin

特點:系統(tǒng)默認(rèn)先去當(dāng)前程徑下找要執(zhí)行的程序,假如沒有,再去path中設(shè)立的途徑下

找。

classpath的配置:

1):永久配置方式:classpath=.;c:\;e:\

<>2):臨時配置方式:setc1asspath=.;c:\;e:\

注意:在定義classpath環(huán)境變量時,需要注意的情況

假如沒有定義環(huán)境變量classpath,java啟動jvm后,會在當(dāng)前目錄下查找要運(yùn)營的類文獻(xiàn);

假如指定了classpath,那么會在指定的目錄下查找要運(yùn)營的類文獻(xiàn)。

還會在當(dāng)前目錄找嗎?兩種情況:

1):假如classpath的值結(jié)尾處有分號,在具體途徑中沒有找到運(yùn)營的類,會默認(rèn)在當(dāng)

前目錄再找一次。

。2):假如classpath的值結(jié)果出沒有分號,在具體的途徑中沒有找到運(yùn)營的類,不會再當(dāng)前

目錄找。

假如沒有在指定目錄下找到要運(yùn)營的類文獻(xiàn),就報錯,這樣可以調(diào)試程

序。

4,javac命令和java命令做什么事情呢?

。要知道java是分兩部分的:一個是編譯,一個是運(yùn)營。

?javac:負(fù)責(zé)的是編譯的部分,當(dāng)執(zhí)行javac時,會啟動java的編譯器程序。對指定擴(kuò)展名

的.java文獻(xiàn)進(jìn)行編譯。生成了jvm可以辨認(rèn)的字節(jié)碼文獻(xiàn)。也就是class文獻(xiàn),也就是java

的運(yùn)營程序。

java:負(fù)責(zé)運(yùn)營的部分.會啟動jvm.加載運(yùn)營時所需的類庫,并對class文獻(xiàn)進(jìn)行執(zhí)行.

。一個文獻(xiàn)要被執(zhí)行,必須要有一個執(zhí)行的起始點,這個起始點就是main函數(shù).

當(dāng)我在虛擬機(jī)中進(jìn)行軟件評測時,也許系統(tǒng)同樣會崩潰,但是,崩潰的只是虛擬機(jī)上的操作

系統(tǒng),而不是物理計算機(jī)上的操作系統(tǒng),并且,使用虛擬機(jī)的“Undo”(恢復(fù))功能,我可以立即恢

復(fù)虛擬機(jī)到安裝軟件之前的狀態(tài)。

二:java語法基礎(chǔ):

1,關(guān)鍵字:其實就是某種語言賦予了特殊含義的單詞。

保存字:其實就是還沒有賦予特殊含義,但是準(zhǔn)備日后要使用過的單詞。

2,標(biāo)示符:其實就是在程序中自定義的名詞。比如類名,變量名,函數(shù)名。包含0-9、a-z、$、

一?

。注意:

4),數(shù)字不可以開頭。

2),不可以使用關(guān)鍵字。

3,常量:是在程序中的不會變化的數(shù)據(jù)。

4,變量:其實就是內(nèi)存中的一個存儲空間,用于存儲常量數(shù)據(jù)。

。作用:方便于運(yùn)算。由于有些數(shù)據(jù)不擬定。所以擬定該數(shù)據(jù)的名詞和存儲空間。

特點:變量空間可以反復(fù)使用。

什么時候定義變量?只要是數(shù)據(jù)不擬定的時候,就定義變量。

變量空間的開辟需要什么要素呢?

這個空間要存儲什么數(shù)據(jù)?數(shù)據(jù)類型。

。2,這個空間叫什么名字???變量名稱。

。3,這個空間的第一次的數(shù)據(jù)是什么?變量的初始化值。

變量的作用域和生存期:

變量的作用域:

作用域從變量定義的位置開始,到該變量所在的那對大括號結(jié)束;

生命周期:

變量從定義的位置開始就在內(nèi)存中活了;

變量到達(dá)它所在的作用域的時候就在內(nèi)存中消失了;

數(shù)據(jù)類型:

o1):基本數(shù)據(jù)類型:byte、short、int、1ong、float、double、char、boolean

?2):引用數(shù)據(jù)類型:數(shù)組、類、接口。

級別從低到高為:byte,char,short(這三個平級)—>int—>float—>Iong—>d

ouble

自動類型轉(zhuǎn)換:從低檔別到高級別,系統(tǒng)自動轉(zhuǎn)的;

強(qiáng)制類型轉(zhuǎn)換:什么情況下使用?把一個高級別的數(shù)賦給一個別該數(shù)的級別低的變量;

運(yùn)算符號:

。1)、算術(shù)運(yùn)算符。

+-*/%%:任何整數(shù)模2不是0就是1,所以只要改變被模數(shù)就可以實現(xiàn)

開關(guān)運(yùn)算。

。+:連接符。

。++,一

。2)、賦值運(yùn)算符。

后+=—=/=%=

3)、比較運(yùn)算符。

8特點:該運(yùn)算符的特點是:運(yùn)算完的結(jié)果,要么是true,要么是false。

4)、邏輯運(yùn)算符。

&|八!&&||

邏輯運(yùn)算符除了!外都是用于連接兩個boolean類型表達(dá)式。

0&:只有兩邊都為true結(jié)果是true。否則就是faIse。

I:只要兩邊都為false結(jié)果是faIse,否則就是true

。八:異或:和或有點不同樣。

。兩邊結(jié)果同樣,就為false。

兩邊結(jié)果不同樣,就為true.

&和&&區(qū)別:&:無論左邊結(jié)果是什么,右邊都參與運(yùn)算。

。。。&&:短路與,假如左邊為false,那么右邊不參數(shù)與運(yùn)算。

I和II區(qū)別:I:兩邊都運(yùn)算。

。||:短路或,假如左邊為true,那么右邊不參與運(yùn)算。

5)、位運(yùn)算符:用于操作二進(jìn)制位的運(yùn)算符。

假I

?<<?>>>(無符號右移)

。練習(xí):對兩個變量的數(shù)據(jù)進(jìn)行互換。不需要第三方變量。

minta=3,b=5;一>b=3,a=5;

aa=a+b;a=8;

=a-b;b=3;

a=a-b;a=5;

aa=ab;//

。b=ab;//b=a"b"b=a

06a=ab;//a=aba=b;

。練習(xí):高效的算出2*8=2〈V3;

5,語句。

Ifswitchdowhi1ewhi1efor

。這些語句什么時候用?

。1)、當(dāng)判斷固定個數(shù)的值的時候,可以使用if,也可以使用switch。

但是建議使用switch,效率相對較高。

switch(變量)(

。case值:要執(zhí)行的語句;break;

defauIt:要執(zhí)行的語句;

工作原理:用小括號中的變量的值依次和case后面的值進(jìn)行對比,和哪個case后面的值相同

T

就執(zhí)行哪個Case后面的語句,假如沒有相同的則執(zhí)行defau1t后面的語句;

細(xì)節(jié):1):break是可以省略的,假如省略了就一直執(zhí)行到碰到break為止;

。2):switch后面的小括號中的變量應(yīng)當(dāng)是byte,char,short,int四種類型中的一種;

63):default可以寫在switch結(jié)構(gòu)中的任意位置;假如將defau1t語句放在了第一行,則

不管expression與case中的value是否匹配,程序會從defauIt開始執(zhí)行直到第一個br

eak出現(xiàn)。

2)、當(dāng)判斷數(shù)據(jù)范圍,獲取判斷運(yùn)算結(jié)果boolean類型時,需要使用if。

。3)、當(dāng)某些語句需要執(zhí)行很多次時,就用循環(huán)結(jié)構(gòu)。

while和for可以進(jìn)行互換。

。區(qū)別在于:假如需要定義變量控制循環(huán)次數(shù)。建議使用foro由于for循環(huán)完畢,變量在內(nèi)存中

釋放。

break:作用于switch,和循環(huán)語句,用于跳出,或者稱為結(jié)束。

break語句單獨存在時,下面不要定義其他語句,由于執(zhí)行不到,編譯會失敗。當(dāng)循環(huán)嵌套時,

break只跳出當(dāng)前所在循環(huán)。要跳出嵌套中的外部循環(huán),只要給循環(huán)起名字即可,這個名字稱之

為標(biāo)號。

continue:只作用于循環(huán)結(jié)構(gòu),繼續(xù)循環(huán)用的。

作用:結(jié)束本次循環(huán),繼續(xù)下次循環(huán)。該語句單獨存在時,下面不可以定義語句,執(zhí)行不到。

6,函數(shù):為了提高代碼的復(fù)用性,可以將其定義成一個單獨的功能,該功能的體現(xiàn)就是java

中的函數(shù)。函數(shù)就是體現(xiàn)之一。

java中的函數(shù)的定義格式:

。修飾符返回值類型函數(shù)名(參數(shù)類型形式參數(shù)1,參數(shù)類型形式參數(shù)1,…)(

也行語句;

9return返回值;

?)

當(dāng)函數(shù)沒有具體的返回值時,返回的返回值類型用void關(guān)鍵字表達(dá)。

假如函數(shù)的返回值類型是void時,return語句可以省略不寫的,系統(tǒng)會幫你自動加上。

return的作用:結(jié)束函數(shù)。結(jié)束功能。

如何定義一個函數(shù)?

。函數(shù)其實就是一個功能,定義函數(shù)就是實現(xiàn)功能,通過兩個明確來完畢:

。1)、明確該功能的運(yùn)算完的結(jié)果,其實是在明確這個函數(shù)的返回值類型。

2)、在實現(xiàn)該功能的過程中是否有未知內(nèi)容參與了運(yùn)算,其實就是在明確這個函數(shù)的參數(shù)

列表(參數(shù)類型&參數(shù)個數(shù))。

函數(shù)的作用:

1)、用于定義功能。

2)、用于封裝代碼提高代碼的復(fù)用性。

注意:函數(shù)中只能調(diào)用函數(shù),不能定義函數(shù)。

主函數(shù):

。1)、保證該類的獨立運(yùn)營。

2)、由于它是程序的入口。

3)、由于它在被jvm調(diào)用。

函數(shù)定義名稱是為什么呢?

答:1)、為了對該功能進(jìn)行標(biāo)示,方便于調(diào)用。

2)、為了通過名稱就可以明確函數(shù)的功能,為了增長代碼的閱讀性。

重載的定義是:在一個類中,假如出現(xiàn)了兩個或者兩個以上的同名函數(shù),只要它們的參數(shù)的個數(shù),

或者參數(shù)的類型不同,即可稱之為該函數(shù)重載了。

如何區(qū)分重載:當(dāng)函數(shù)同名時,只看參數(shù)列表。和返回值類型沒關(guān)系。

7,數(shù)組:用于存儲同一類型數(shù)據(jù)的一個容器。好處:可以對該容器中的數(shù)據(jù)進(jìn)行編號,從0開

始。數(shù)組用于封裝數(shù)據(jù),就是一個具體的實體。

如何在java中表現(xiàn)一個數(shù)組呢?兩種表現(xiàn)形式。

1)、元素類型口變量名=new元素類型[元素的個數(shù)];

2)、元素類型口變量名={元素1,元素2...};

元素類型口變量名=new元素類型口{元素1,元素2...};

〃二分查找法。必須有前提:數(shù)組中的元素要有序。

opub1icstaticintha1fSeach_2(int[]arr,intkey){

intmin,max,mid;

。min=0;

emax=arr.length-1;

。mid=(max+min)>>1;//(max+min)/2;

??>while(arr[mid]!=key){

^if(key>arr[mid]){

^min=mid+1;

00}

elseif(key<arr[mid])

吟max=mid-1;

gif(max<min)

次return—1;

gmid=(max+min)>>1;

}

。returnmid;

)

java分了5片內(nèi)存。

1:寄存器。2:本地方法區(qū)。3:方法區(qū)。4:棧。5:堆。

棧:存儲的都是局部變量(函數(shù)中定義的變量,函數(shù)上的參數(shù),語句中的變量);

只要數(shù)據(jù)運(yùn)算完畢所在的區(qū)域結(jié)束,該數(shù)據(jù)就會被釋放。

堆:用于存儲數(shù)組和對象,也就是實體。啥是實體啊?就是用于封裝多個數(shù)據(jù)的。

1:每一個實體都有內(nèi)存首地址值。

2:堆內(nèi)存中的變量都有默認(rèn)初始化值。由于數(shù)據(jù)類型不同,值也不同樣。

3:垃圾回收機(jī)制。

三:面向?qū)ο螅骸铩铩铩铩?/p>

特點:1:將復(fù)雜的事情簡樸化。

2:面向?qū)ο髮⒁郧暗倪^程中的執(zhí)行者,變成了指揮者。

3:面向?qū)ο筮@種思想是符合現(xiàn)在人們思考習(xí)慣的一種思想。

過程和對象在我們的程序中是如何體現(xiàn)的呢?過程其實就是函數(shù);對象是將函數(shù)等一些內(nèi)容進(jìn)行了

封裝。

匿名對象使用場景:

1:當(dāng)對方法只進(jìn)行一次調(diào)用的時候,可以使用匿名對象。

2:當(dāng)對象對成員進(jìn)行多次調(diào)用時,不能使用匿名對象。必須給對象起名字。

在類中定義其實都稱之為成員。成員有兩種:

1:成員變量:其實相應(yīng)的就是事物的屬性。

2:成員函數(shù):其實相應(yīng)的就是事物的行為。

所以,其實定義類,就是在定義成員變量和成員函數(shù)。但是在定義前,必須先要對事物進(jìn)行屬性

和行為的分析,才可以用代碼來體現(xiàn)。

privateintage;〃私有的訪問權(quán)限最低,只有在本類中的訪問有效。

注意:私有僅僅是封裝的一種體現(xiàn)形式而已。

私有的成員:其他類不能直接創(chuàng)建對象訪問,所以只有通過本類對外提供具體的訪問方式來完畢對

私有的訪問,可以通過對外提供函數(shù)的形式對其進(jìn)行訪問。

好處:可以在函數(shù)中加入邏輯判斷等操作,對數(shù)據(jù)進(jìn)行判斷等操作。

總結(jié):開發(fā)時,記住,屬性是用于存儲數(shù)據(jù)的,直接被訪問,容易出現(xiàn)安全隱患,所以,類中的屬性

通常被私有化,并對外提供公共的訪問方法。

這個方法一般有兩個,規(guī)范寫法:對于屬性XXX,可以使用setXXXO,getXXX。對其進(jìn)行

操作。

類中怎么沒有定義主函數(shù)呢?

注意:主函數(shù)的存在,僅為該類是否需要獨立運(yùn)營,假如不需要,主函數(shù)是不用定義的。

主函數(shù)的解釋:保證所在類的獨立運(yùn)營,是程序的入口,被jvm調(diào)用。

成員變量和局部變量的區(qū)別:

1:成員變量直接定義在類中。

局部變量定義在方法中,參數(shù)上,語句中。

2:成員變量在這個類中有效。

局部變量只在自己所屬的大括號內(nèi)有效,大括號結(jié)束,局部變量失去作用域。

3:成員變量存在于堆內(nèi)存中,隨著對象的產(chǎn)生而存在,消失而消失。

局部變量存在于棧內(nèi)存中,隨著所屬區(qū)域的運(yùn)營而存在,結(jié)束而釋放。

構(gòu)造函數(shù):用于給對象進(jìn)行初始化,是給與之相應(yīng)的對象進(jìn)行初始化,它具有針對性,函數(shù)中的一

種。

特點:

1:該函數(shù)的名稱和所在類的名稱相同。

2:不需要定義返回值類型。

3:該函數(shù)沒有具體的返回值。

記?。核袑ο髣?chuàng)建時,都需要初始化才可以使用。

注意事項:一個類在定義時,假如沒有定義過構(gòu)造函數(shù),那么該類中會自動生成一個空參數(shù)的構(gòu)

造函數(shù),為了方便該類創(chuàng)建對象,完畢初始化。假如在類中自定義了構(gòu)造函數(shù),那么默認(rèn)的構(gòu)造函

數(shù)就沒有了。

一個類中,可以有多個構(gòu)造函數(shù),由于它們的函數(shù)名稱都相同,所以只能通過參數(shù)列表來區(qū)分。

所以,一個類中假如出現(xiàn)多個構(gòu)造函數(shù)。它們的存在是以重載體現(xiàn)的。

構(gòu)造函數(shù)和一般函數(shù)有什么區(qū)別呢?

1:兩個函數(shù)定義格式不同。

2:構(gòu)造函數(shù)是在對象創(chuàng)建時,就被調(diào)用,用于初始化,并且初始化動作只執(zhí)行一次。

一般函數(shù),是對象創(chuàng)建后,需要調(diào)用才執(zhí)行,可以被調(diào)用多次。

什么時候使用構(gòu)造函數(shù)呢?

分析事物時,發(fā)現(xiàn)具體事物一出現(xiàn),就具有了一些特性,那就將這些特性定義到構(gòu)造函數(shù)內(nèi)。

構(gòu)造代碼塊和構(gòu)造函數(shù)有什么區(qū)別?

構(gòu)造代碼塊:是給所有的對象進(jìn)行初始化,也就是說,所有的對象都會調(diào)用一個代碼塊。只要

對象一建立。就會調(diào)用這個代碼塊。

構(gòu)造函數(shù):是給與之相應(yīng)的對象進(jìn)行初始化。它具有針對性。

Personp=newPerson();

創(chuàng)建一個對象都在內(nèi)存中做了什么事情?

1:先將硬盤上指定位置的Person.class文獻(xiàn)加載進(jìn)內(nèi)存。

2:執(zhí)行main方法時,在棧內(nèi)存中開辟了main方法的空間(壓棧一進(jìn)棧),然后在main方法

的棧區(qū)分派了一個變量P。

3:在堆內(nèi)存中開辟一個實體空間,分派了一個內(nèi)存首地址值。new

4:在該實體空間中進(jìn)行屬性的空間分派,并進(jìn)行了默認(rèn)初始化。

5:對空間中的屬性進(jìn)行顯示初始化。

6:進(jìn)行實體的構(gòu)造代碼塊初始化。

7:調(diào)用該實體相應(yīng)的構(gòu)造函數(shù),進(jìn)行構(gòu)造函數(shù)初始化。()

8:將首地址賦值給p,p變量就引用了該實體。(指向了該對象)

封裝(面向?qū)ο筇匦灾唬菏侵鸽[藏對象的屬性和實現(xiàn)細(xì)節(jié),僅對外提供公共訪問方式。

好處:將變化隔離;便于使用;提高重用性;安全性。

封裝原則:將不需要對外提供的內(nèi)容都隱藏起來,把屬性都隱藏,提供公共方法對其訪問。

this:代表對象。就是所在函數(shù)所屬對象的引用。

this到底代表什么呢?哪個對象調(diào)用了this所在的函數(shù),this就代表哪個對象,就是哪個對象

的引用。

開發(fā)時,什么時候使用thiS呢?

在定義功能時,假如該功能內(nèi)部使用到了調(diào)用該功能的對象,這時就用this來表達(dá)這個對象。

this還可以用于構(gòu)造函數(shù)間的調(diào)用。

調(diào)用格式:this(實際參數(shù));

this對象后面跟上.調(diào)用的是成員屬性和成員方法(一般方法);

this對象后面跟上()調(diào)用的是本類中的相應(yīng)參數(shù)的構(gòu)造函數(shù)。

注意:用this調(diào)用構(gòu)造函數(shù),必須定義在構(gòu)造函數(shù)的第一行。由于構(gòu)造函數(shù)是用于初始化的,所

以初始化動作一定要執(zhí)行。否則編譯失敗。

Static:★★★關(guān)鍵字,是一個修飾符,用于修飾成員(成員變量和成員函數(shù))。

特點:

1,想要實現(xiàn)對象中的共性數(shù)據(jù)的對象共享??梢詫⑦@個數(shù)據(jù)進(jìn)行靜態(tài)修飾。

2,被靜態(tài)修飾的成員,可以直接被類名所調(diào)用。也就是說,靜態(tài)的成員多了一種調(diào)用方式。

類名.靜態(tài)方式。

3,靜態(tài)隨著類的加載而加載。并且優(yōu)先于對象存在。

弊端:

1,有些數(shù)據(jù)是對象特有的數(shù)據(jù),是不可以被靜態(tài)修飾的。由于那樣的話,特有數(shù)據(jù)會變成對象的

共享數(shù)據(jù)。這樣對事物的描述就出了問題。所以,在定義靜態(tài)時,必須要明確,這個數(shù)據(jù)是否是被

對象所共享的。

2,靜態(tài)方法只能訪問靜態(tài)成員,不可以訪問非靜態(tài)成員。

(這句話是針對同一個類環(huán)境下的,比如說,一個類有多個成員(屬性,方法,字段),靜態(tài)方法

A,那么可以訪問同類名下其他靜態(tài)成員,你假如訪問非靜態(tài)成員就不行)

由于靜態(tài)方法加載時,優(yōu)先于對象存在,所以沒有辦法訪問對象中的成員。

3,靜態(tài)方法中不能使用this,super關(guān)鍵字。

由于this代表對象,而靜態(tài)在時,有也許沒有對象,所以this無法使用。

4,主函數(shù)是靜態(tài)的。

什么時候定義靜態(tài)成員呢?或者說:定義成員時,到底需不需要被靜態(tài)修飾呢?

成員分兩種:

1,成員變量。(數(shù)據(jù)共享時靜態(tài)化)

該成員變量的數(shù)據(jù)是否是所有對象都同樣:

那么該

假如不是,那么就說這是對象的特有數(shù)據(jù),要存儲到對象中。

2,成員函數(shù)。

假如判斷成員函數(shù)是否需要被靜態(tài)修飾呢?

。只要參考,該函數(shù)內(nèi)是否訪問了對象中的特有數(shù)據(jù):

假如有訪問特有數(shù)據(jù),那方法不能被靜態(tài)修飾。

。假如沒有訪問過特有數(shù)據(jù),那么這個方法需要被靜態(tài)修飾。

成員變量和靜態(tài)變量的區(qū)別:

1,成員變量所屬于對象。所以也稱為實例變量。

靜態(tài)變量所屬于類。所以也稱為類變量。

2,成員變量存在于堆內(nèi)存中。

靜態(tài)變量存在于方法區(qū)中。

3,成員變量隨著對象創(chuàng)建而存在。隨著對象被回收而消失。

靜態(tài)變量隨著類的加載而存在。隨著類的消失而消失。

4,成員變量只能被對象所調(diào)用。

靜態(tài)變量可以被對象調(diào)用,也可以被類名調(diào)用。

所以,成員變量可以稱為對象的特有數(shù)據(jù),靜態(tài)變量稱為對象的共享數(shù)據(jù)。

靜態(tài)的注意:靜態(tài)的生命周期很長。

靜態(tài)代碼塊:就是一個有靜態(tài)關(guān)鍵字標(biāo)示的一個代碼塊區(qū)域。定義在類中。

作用:可以完畢類的初始化。靜態(tài)代碼塊隨著類的加載而執(zhí)行,并且只執(zhí)行一次(new多個對

象就只執(zhí)行一次)。假如和主函數(shù)在同一類中,優(yōu)先于主函數(shù)執(zhí)行。

Public:訪問權(quán)限最大。

static:不需要對象,直接類名即可。

void:主函數(shù)沒有返回值。

Main:主函數(shù)特定的名稱。

(String[]args):主函數(shù)的參數(shù),是一個字符串?dāng)?shù)組類型的參數(shù),jvm調(diào)用main方法時,

傳遞的實際參數(shù)是newString[。]。

jvm默認(rèn)傳遞的是長度為0的字符串?dāng)?shù)組,我們在運(yùn)營該類時,也可以指定具體的參數(shù)進(jìn)行傳遞。

可以在控制臺,運(yùn)營該類時,在后面加入?yún)?shù)。參數(shù)之間通過空格隔開。jvm會自動將這些字符串

參數(shù)作為args數(shù)組中的元素,進(jìn)行存儲。

靜態(tài)代碼塊、構(gòu)造代碼塊、構(gòu)造函數(shù)同時存在時的執(zhí)行順序:靜態(tài)代碼塊-?構(gòu)造代碼塊分

構(gòu)造函數(shù);

生成Java幫助文檔:命令格式:javadoc-d文獻(xiàn)夾名-auther-version*.java

/**//格式

*類描述

*@author作者名

*@version版本號

*/

/**

*方法描述

*@param參數(shù)描述

*@return返回值描述

*/

設(shè)計模式:解決問題最行之有效的思想。是一套被反復(fù)使用、多數(shù)人知曉的、通過度類編目的、

代碼設(shè)計經(jīng)驗的總結(jié)。使用設(shè)計模式是為了可重用代碼、讓代碼更容易被別人理解、保證代碼可

靠性。

java中有23種設(shè)計模式:

單例設(shè)計模式:★★★★★

解決的問題:保證一個類在內(nèi)存中的對象唯一性。

比如:多程序讀取一個配置文獻(xiàn)時,建議配置文獻(xiàn)封裝成對象。會方便操作其中數(shù)據(jù),又要保證多

個程序讀到的是同一個配置文獻(xiàn)對象,就需要該配置文獻(xiàn)對象在內(nèi)存中是唯一的。

Runtime()方法就是單例設(shè)計模式進(jìn)行設(shè)計的。

如何保證對象唯一性呢?

思想:

1,不讓其他程序創(chuàng)建該類對象。

2,在本類中創(chuàng)建一個本類對象。

3,對外提供方法,讓其他程序獲取這個對象。

環(huán)節(jié):

1,由于創(chuàng)建對象都需要構(gòu)造函數(shù)初始化,只要將本類中的構(gòu)造函數(shù)私有化,其他程序就無法再

創(chuàng)建該類對象;

2,就在類中創(chuàng)建一個本類的對象;

3,定義一個方法,返回該對象,讓其他程序可以通過方法就得到本類對象。(作用:可控)

代碼體現(xiàn):

1,私有化構(gòu)造函數(shù);

2,創(chuàng)建私有并靜態(tài)的本類對象;

3,定義公有并靜態(tài)的方法,返回該對象。

//餓漢式

classSingle{

privateSingle(){}〃私有化構(gòu)造函數(shù)。

privatestaticSingles=newSing1e();〃創(chuàng)建私有并靜態(tài)的本類對象。

?publiestaticSinglegetInstance(){//定義公有并靜態(tài)的方法,返回該對象。

returns;

〃懶漢式:延遲加載方式。

classSing1e2{

?privateSingle2(){}

privatestaticSingle2s=nul1;

publicstaticSingle2getInstance(){

~if(s==null)

0SnewSingle2()

return

}

)

繼承(面向?qū)ο筇匦灾唬?/p>

好處:

1:提高了代碼的復(fù)用性。

2:讓類與類之間產(chǎn)生了關(guān)系,提供了另一個特性多態(tài)的前提。

父類的由來:其實是由多個類不斷向上抽取共性內(nèi)容而來的。

java中對于繼承,java只支持單繼承。java雖然不直接支持多繼承,但是保存了這種多繼承機(jī)

制,進(jìn)行改良。

單繼承:一個類只能有一個父類。

多繼承:一個類可以有多個父類。

為什么不支持多繼承呢?

由于當(dāng)一個類同時繼承兩個父類時,兩個父類中有相同的功能,那么子類對象調(diào)用該功能時,運(yùn)

營哪一個呢?由于父類中的方法中存在方法體。

但是java支持多重繼承。A繼承BB繼承CC繼承D。

多重繼承的出現(xiàn),就有了繼承體系。體系中的頂層父類是通過不斷向上抽取而來的。它里面

定義的該體系最基本最共性內(nèi)容的功能。

所以,一個體系要想被使用,直接查閱該系統(tǒng)中的父類的功能即可知道該體系的基本用法。那

么想要使用一個體系時,需要建立對象。由于最子類不僅可以使用父類中的

功能。還可以使用子類特有的一些功能。

簡樸說:對于一個繼承體系的使用,查閱頂層父類中的內(nèi)容,創(chuàng)建最底層子類的對象。

子父類出現(xiàn)后,類中的成員都有了哪些特點:

1:成員變量。

當(dāng)子父類中出現(xiàn)同樣的屬性時,子類類型的對象,調(diào)用該屬性,值是子類的屬性值。

假如想要調(diào)用父類中的屬性值,需要使用一個關(guān)鍵字:super

。This:代表是本類類型的對象引用。

Super:代表是子類所屬的父類中的內(nèi)存空間引用。

。注意:子父類中通常是不會出現(xiàn)同名成員變量的,由于父類中只要定義了,子類就不用在定義

了,直接繼承過來用就可以了。

2:成員函數(shù)。

當(dāng)子父類中出現(xiàn)了一模同樣的方法時,建立子類對象會運(yùn)營子類中的方法。仿佛父類中的方法

被覆蓋掉同樣。所以這種情況,是函數(shù)的另一個特性:覆蓋(復(fù)寫,■)

什么時候使用覆蓋呢?當(dāng)一個類的功能內(nèi)容需要修改時,可以通過覆蓋來實現(xiàn)。

3:構(gòu)造函數(shù)。

發(fā)現(xiàn)子類構(gòu)造函數(shù)運(yùn)營時,先運(yùn)營了父類的構(gòu)造函數(shù)。為什么呢?

因素:子類的所有構(gòu)造函數(shù)中的第一行,其實都有一條隱身的語句super();

super():表達(dá)父類的構(gòu)造函數(shù),并會調(diào)用于參數(shù)相相應(yīng)的父類中的構(gòu)造函數(shù)。而super

0:是在調(diào)用父類中空參數(shù)的構(gòu)造函數(shù)。

為什么子類對象初始化時,都需要調(diào)用父類中的函數(shù)?(為什么要在子類構(gòu)造函數(shù)的第一行加

入這個super()?)

由于子類繼承父類,會繼承到父類中的數(shù)據(jù),所以必須要看父類是如何對自己的數(shù)據(jù)進(jìn)行初始

化的。所以子類在進(jìn)行對象初始化時,先^這就是子類的實例化過程

注意:子類中所有的構(gòu)造函數(shù)都會默認(rèn)訪問父類中的空參數(shù)的構(gòu)造函數(shù),由于每一個子類構(gòu)造

內(nèi)第一行都有默認(rèn)的語句super();

假如父類中沒有空參數(shù)的構(gòu)造函數(shù),那么子類的構(gòu)造函數(shù)內(nèi),必須通過super語句指定要訪

問的父類中的構(gòu)造函數(shù).

假如子類構(gòu)造函數(shù)中用this來指定調(diào)用子類自己的構(gòu)造函數(shù),那么被調(diào)用的構(gòu)造函數(shù)也同樣

會訪問父類中的構(gòu)造函數(shù)。

問題:super()和this。是否可以同時出現(xiàn)的構(gòu)造函數(shù)中。

兩個語句只能有一個定義在第一行,所以只能出現(xiàn)其中一個。

super()或者this。:為什么一定要定義在第一行?

由于super。或者this()都是調(diào)用構(gòu)造函數(shù),構(gòu)造函數(shù)用于初始化,所以初始化的動作要

先完畢。

繼承的細(xì)節(jié):

什么時候使用繼承呢?

當(dāng)類與類之間存在著所屬關(guān)系時,才具有了繼承的前提。a是b中的一種。a繼承b。狼是犬

科中的一種。

英文書中,所屬關(guān)系:〃isa"

注意:不要僅僅為了獲取其他類中的已有成員進(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)鍵字,fina1:最終。

fina1特點:

1:這個關(guān)鍵字是一個修飾符,可以修飾類,方法,變量。

2:被final修飾的類是一個最終類,不可以被繼承。

3:被fina1修飾的方法是一個最終方法,不可以被覆蓋。

4:被final修飾的變量是一個常量,只能賦值一次。

其實這樣的因素的就是給一些固定的數(shù)據(jù)起個閱讀性較強(qiáng)的名稱。

不加final修飾不是也可以使用嗎?那么這個值是一個變量,是可以更改的。加了fina

1,程序更為嚴(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)造函數(shù)?有,用于給子類對象進(jìn)行初始化。

2:抽象類中是否可以定義非抽象方法?

??梢浴F鋵?,抽象類和一般類沒有太大的區(qū)別,都是在描述事物,只但是抽象類在描述事物時,有

些功能不具體。所以抽象類和一般類在定義上,都是需要定義屬性和行為的。只但是,比一般類多

了一個抽象函數(shù)。并且比一般類少了一個創(chuàng)建對象的部分。

3:抽象關(guān)鍵字abstract和哪些不可以共存?final,private,static

4:抽象類中可不可以不定義抽象方法?可以。抽象方法目的僅僅為了不讓該類創(chuàng)建對象。

模板方法設(shè)計模式:

解決的問題:當(dāng)功能內(nèi)部一部分實現(xiàn)時擬定,一部分實現(xiàn)是不擬定的。這時可以把不擬定的部分暴

露出去,讓子類去實現(xiàn)。

abstractclassGetTime{

publicfinalvoidgetTimeO(〃此功能假如不需要復(fù)寫,可加fina1限定

。longstart=Systern.currentTimeMi11is();

ocode();//不擬定的功能部分,提取出來,通過抽象方法實現(xiàn)

hongend=System,currentTimeMillis();

6System.out.printIn("毫秒是:〃+(end-start));

。}

publicabstractvoidcode();〃抽象不擬定的功能,讓子類復(fù)寫實現(xiàn)

)

c1assSubDemoextendsGetTime{

^publicvoidcode(){〃子類復(fù)寫功能方法

。for(inty=0;y<l000;y++){

BoSystem.out.println(〃y〃);

。)

接口:★★★★★

1:是用關(guān)鍵字interface定義的。

2:接口中包含的成員,最常見的有全局常量、抽象方法。

注意:接口中的成員都有固定的修飾符。

。成員變量:publicstaticfinal

成員方法:publicabstract

interfaceInter{

pub1icstaticfinalintx=3;

publieabstractvoidshow();

3:接口中有抽象方法,說明接口不可以實例化。接口的子類必須實現(xiàn)了接口中所有的抽象方法

后,該子類才可以實例化。否則,該子類還是一個抽象類。

4:類與類之間存在著繼承關(guān)系,類與接口中間存在的是實現(xiàn)關(guān)系。

0繼承用extends;實現(xiàn)用imp1ements;

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:抽象類使用的是isa關(guān)系。

接口使用的likea關(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ū)ο筇匦灾唬汉瘮?shù)自身就具有多態(tài)性,某一種事物有不同的具體的體

現(xiàn)。

體現(xiàn):父類引用或者接口的引用指向了自己的子類對象。//Animala=newCat。;,

可以調(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)。

c1ass畢姥爺{

?void講課(){

。System.out.printin("公司管理”);

8}

void釣魚(){

。System.out.printin("釣魚");

}

class畢老師extends畢姥爺{

?void講課()(

oSystem.out.printin("JAVA");

s!

void看電影(){

System.out.printin("看電影");

?)

c1ass{

opublicstaticvoidmain(String[]args){

8畢姥爺x=new畢老師();//畢老師對象被提高為了畢姥爺類型。

〃。x.講課();

〃。x.看電影();//錯誤.

g畢老師y=(畢老師)x;〃將畢姥爺類型強(qiáng)制轉(zhuǎn)換成畢老師類型。

y.看電影();

?)

假如想用子類對象的特有方法,如何判斷對象是哪個具體的子類類型呢?

可以可以通過一個關(guān)鍵字instanceof;//判斷對象是否實現(xiàn)了指定的接口或繼承了指定

的類

格式:〈對象instanceof類型>,判斷一個對象是否所屬于指定的類型。

StudentinstanceofPerson=true;//student繼承了person類

多態(tài)在子父類中的成員上的體現(xiàn)的特點:

1,成員變量:在多態(tài)中,子父類成員變量同名。

。在編譯時期:參考的是引用型變量所屬的類中是否有調(diào)用的成員。(編譯時不產(chǎn)生對象,只檢查語

法錯誤)

運(yùn)營時期:也是參考引用型變量所屬的類中是否有調(diào)用的成員。

。簡樸一句話:無論編譯和運(yùn)營,成員變量參考的都是引用變量所屬的類中的成員變量。

。再說的更容易記憶一些:成員變量——編譯運(yùn)營都看=左邊。

2,成員函數(shù)。

。編譯時期:參考引用型變量所屬的類中是否有調(diào)用的方法。

運(yùn)營事情:參考的是對象所屬的類中是否有調(diào)用的方法。

。為什么是這樣的呢?由于在子父類中,對于一模同樣的成員函數(shù),有一個特性:覆蓋。

簡樸一句:成員函數(shù),編譯看引用型變量所屬的類,運(yùn)營看對象所屬的類。

更簡樸:成員函數(shù)---編譯看=左邊,運(yùn)營看=右邊。

3,靜態(tài)函數(shù)。

。編譯時期:參考的是引用型變量所屬的類中是否有調(diào)用的成員。

。運(yùn)營時期:也是參考引用型變量所屬的類中是否有調(diào)用的成員。

為什么是這樣的呢?由于靜態(tài)方法,其實不所屬于對象,而是所屬于該方法所在的類。

調(diào)用靜態(tài)的方法引用是哪個類的引用調(diào)用的就是哪個類中的靜態(tài)方法。

。簡樸說:靜態(tài)函數(shù)--編譯運(yùn)營都看=左邊。

------java.lang.0bject

Object:所有類的直接或者間接父類,Java認(rèn)為所有的對象都具有一些基本的共性內(nèi)容,這些

內(nèi)容可以不斷的向上抽取,最終就抽取到了一個最頂層的類中的,該類中定義的就是所有對象都具

有的功能。

具體方法:

1,booleanequaIs(Objectobj):用于比較兩個對象是否相等,其實內(nèi)部比較的就是兩

個對象地址。假如根據(jù)equals(Object)方法,兩個對象是相等的,那么對這兩個對象中

的每個對象調(diào)用hashCode方法都必須生成相同的整數(shù)結(jié)果;

而根據(jù)對象的屬性不同,判斷對象是否相同的具體內(nèi)容也不同樣。所以在定義類時,一般都會

復(fù)寫equals方法,建立本類特有的判斷對象是否相同的依據(jù)。

publicbooleanequals(Objectobj){

if(!(objinstanceofPerson))

^returnfalse;

Personp(Person)obj;

oreturnthis,age==p.age;

2,StringtoString():將對象變成字符串;默認(rèn)返回的格式:類名@哈希值=

getClassO.getName()+'+Integer.toHexString(hashCode())

。為了對象相應(yīng)的字符串內(nèi)容故意義,可以通過復(fù)寫,建立該類對象自己特有的字符串表現(xiàn)形

publicStringtoString()

greturn"person:,z+age;

3,ClassgetClass():獲取任意對象運(yùn)營時的所屬字節(jié)碼文獻(xiàn)對象。

4,inthashCode():返回該對象的哈希碼值。支持此方法是為了提高哈希表的性能。將該

對象的內(nèi)部地址轉(zhuǎn)換成一個整數(shù)來實現(xiàn)的。

通常equals,toString,hashCode,在應(yīng)用中都會被復(fù)寫,建立具體對象的特有的內(nèi)容。

內(nèi)部類:假如A類需要直接訪問B類中的成員,而B類又需要建立A類的對象。這時,為了方便

設(shè)計和訪問,直接將A類定義在B類中。就可以了。A類就稱為內(nèi)部類。

classOuter

?intnum=4;。

。classnner

avoidshow(){

System,out.println(〃innershowrun〃+num);

pub1icvoidmethod(){

sInnerin=newInner();//創(chuàng)建內(nèi)部類的對象。

。in.showO;〃調(diào)用內(nèi)部類的方法。//內(nèi)部類直接訪問外部類成員,用自己的實例對

象;

}a。。//外部類訪問內(nèi)部類要定義內(nèi)部類的對象;

)

當(dāng)內(nèi)部類定義在外部類中的成員位置上,可以使用一些成員修飾符修飾private,statico

1:默認(rèn)修飾符。

直接訪問內(nèi)部類格式:外部類名.內(nèi)部類名變量名=外部類對象.內(nèi)部類對象;

Outer.Innerin=new0uter.newInner();〃這種形式很少用。

。但是這種應(yīng)用不多見,由于內(nèi)部類之所以定義在內(nèi)部就是為了封裝。想要獲取內(nèi)部類對象通常

都通過外部類的方法來獲取。這樣可以對內(nèi)部類對象進(jìn)行控制。

2:私有修飾符。

通常內(nèi)部類被封裝,都會被私有化,由于封裝性不讓其他程序直接訪問。

3:靜態(tài)修飾符。

被如內(nèi)部類被靜態(tài)修飾,相稱于外部類,會出現(xiàn)訪問局限性,只能訪問外部類中的靜態(tài)成員。

注意;假如內(nèi)部類中定義了靜態(tài)成員,那么該內(nèi)部類必須是靜態(tài)的。

內(nèi)部類編譯后的文獻(xiàn)名為:“外部類名$內(nèi)部類名.java”;

為什么內(nèi)部類可以直接訪問外部類中的成員呢?

那是由于內(nèi)部中都持有一個外部類的引用。這個是引用是外部類名.this

內(nèi)部類可以定義在外部類中的成員位置上,也可以定義在外部類中的局部位置上。

當(dāng)內(nèi)部類被定義在局部位置上,只能訪問局部中被final修飾的局部變量。

匿名內(nèi)部類(對象):沒有名字的內(nèi)部類。就是內(nèi)部類的簡化形式。一般只用一次就可以用這種形

式。匿名內(nèi)部類其實就是一個匿名子類對象。想要定義匿名內(nèi)部類:需要前提,內(nèi)部類必須繼承

一個類或者實現(xiàn)接口。

匿名內(nèi)部類的格式:new父類名&接口名(){定義子類成員或者覆蓋父類方法}?方法。

匿名內(nèi)部類的使用場景:

當(dāng)函數(shù)的參數(shù)是接口類型引用時,假如接口中的方法不超過3個??梢酝ㄟ^匿名內(nèi)部類來完

畢參數(shù)的傳遞。

其實就是在創(chuàng)建匿名內(nèi)部類時,該類中的封裝的方法不要過多,最佳兩個或者兩個以內(nèi)。

//面試

//I

newObject(){

。voidshow(){

?System.out.println("showrun");。?

g}

}.show();?4”/寫法和編譯都沒問題

。//2

Objectobj=newObject(){

。,voidshow(){

。8system.out.println("showrun”);

0)

};

-obj.show()*”/寫法對的,編譯會報錯

b

1和2的寫法對的嗎?有區(qū)別嗎?說出因素。

。寫法是對的,1和2都是在通過匿名內(nèi)部類建立一個Object類的子類對象。

區(qū)別:

。第一個可是編譯通過,并運(yùn)營。

。第二個編譯失敗,由于匿名內(nèi)部類是一個子類對象,當(dāng)用Object的obj引用指向時,就被

提高為了Object類型,而編譯時檢查0bject類中是否有show方法,所以編譯失敗。

classInnerClassDemo6{

^(static)c1assInner{

avoidshow(){}

)

^publicvoidmethod(){

3this.newInner0.show();//可以

)

?pub1icstaticvoidmain(String[]args){//static不允許this

8This.newInner().show();〃錯誤,Inner類需要定義成static

d

}

interfaceInter{

avoidshow();

)

classOuter{〃通過匿名內(nèi)部類補(bǔ)足Outer類中的代碼。

pub1icstaticIntermethod(){“/返回Inter類型的變量;

^returnnewInter(){

publicvoidshow(){}

時;

)

)

classInnerClassDemo7{

pub1icstaticvoidmain(String[]args){

oOuter.method().show();

/*

W)uter.method():意思是:0uter中有一個名稱為method的方法,并且這個方法是靜態(tài)的。

~Outer.methodO.show():當(dāng)0uter類調(diào)用靜態(tài)的method方法運(yùn)算結(jié)束后的結(jié)果又調(diào)

用了show方法,意味著:method()方法運(yùn)算完一個是對象,并且這個對象是Inter類型的。

ofunction(newInter(){

??pub1icvoidshow(){}

?));//匿名內(nèi)部類作為方法的參數(shù)進(jìn)行傳遞。

publicstaticvoidfunction(Interin){

?in.show();

異常:★★★★

異常:就是不正常。程序在運(yùn)營時出現(xiàn)的不正常情況。其實就是程序中出現(xiàn)的問題。這個問

題按照面向?qū)ο笏枷脒M(jìn)行描述,并封裝成了對象。由于問題的產(chǎn)生有產(chǎn)生的因素、有問題的名

稱、有問題的描述等多個屬性信息存在。當(dāng)出現(xiàn)多屬性信息最方便的方式就是將這些信息進(jìn)行封

裝。異常就是java按照面向?qū)ο蟮乃枷雽栴}進(jìn)行對象封裝。這樣就方便于操作問題以及解決

問題。

出現(xiàn)的問題有很多種,比如角標(biāo)越界,空指針等都是。就對這些問題進(jìn)行分類。并且這些問題

都有共性內(nèi)容比如:每一個問題都有名稱,同時尚有問題描述的信息,問題出現(xiàn)的位置,所以可以

不斷的向上抽取。形成了異常體系。

.........-java.lang.Throwab1e:

Throwab1e:可拋出的。

l-Error:錯誤,一般情況下,不編寫針對性的代碼進(jìn)行解決,通常是jvm發(fā)生的,需要對

程序進(jìn)行修正。

I-Exception:異常,可以有針對性的解決方式

無論是錯誤還是異常,它們都有具體的子類體現(xiàn)每一個問題,它們的子類都有一個共性,就是都

以父類名才作為子類的后綴名。

這個體系中的所有類和對象都具有一個獨有的特點;就是可拋性。

可拋性的體現(xiàn):就是這個體系中的類和對象都可以被throws和throw兩個關(guān)鍵字所操作。

classExcept!onDemo{

?publicstaticvoidmain(String[]args){

//bytebuf=newbyte[1024*1024*700];//java.lang.OutOfMemoryEr

ror內(nèi)存溢犯錯誤

)

在開發(fā)時,假如定義功能時,發(fā)現(xiàn)該功能會出現(xiàn)一些問題,應(yīng)當(dāng)將問題在定義功能時標(biāo)示出

來,這樣調(diào)用者就可以在使用這個功能的時候,預(yù)先給出解決方式。

如何標(biāo)示呢?通過throws關(guān)鍵字完畢

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論