版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
Java基礎(chǔ)知識總結(jié)
寫代碼:
1,明確需求。我要做什么?
2,分析思緒。我要怎么做?l,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企業(yè)口勺JamesGosling等人開始開發(fā)名稱為Oak『、J語言,但愿用于控制嵌入在有
線電視互換盒、PDA等的微處理器;
1994年將Oak語言更名為Java;
Java的三種技術(shù)架構(gòu):
JAVAEE:JavaPlatformEnterpriseEdition,開發(fā)企業(yè)環(huán)境下H勺應(yīng)用程序,重要針對web程序開
發(fā);
JAVASE:JavaPlatformStandardEdition,完畢桌面應(yīng)用程序『、J開發(fā),是其他兩者口勺基礎(chǔ);
JAVAME:JavaPlatformMicroEdition,開發(fā)電子消費產(chǎn)品和嵌入式設(shè)備,如中歐I程序;
LJDK:JavaDevelopmentKit,java的開發(fā)和運行環(huán)境,java的開發(fā)工具和jre。
2?JRE:JavaRuntimeEnvironment,java程序H勺運行界境,java運行的所需日勺類庫+JVM(java
虛擬機)。
3,配置環(huán)境變量:讓javajdk\bin目錄下的工具,可以在任意目錄下運行,原因是,將該工具
所在目錄告訴了系統(tǒng),當使用該工具時,由,統(tǒng)?我們上川指定的目錄。
環(huán)境變量的配置:
1):永久配置方式:JAVA_HOME=%安裝途徑外\Java\jdk
path=UAVA_HOME%\bin
2):臨時配置方式:setpath=%path%;C:\ProgramFiles\Java\jdk\bin
特點:系統(tǒng)默認先去目前途徑下找要執(zhí)行日勺程序,假如沒有,再去path中設(shè)置的途徑下
找。
classpath的配置:
1):永久配置方式:classpath=.;c:\;e:\
2):臨時配置方式:setclasspath=.;c:\;e:\
注意:在定義classpath環(huán)境變量時,需要注意日勺狀況
假如沒有定義環(huán)境變量classpath,java啟動jvm后,會在目前目錄下查找要運行日勺類文獻;
假如指定了elAsspAth,那么會在指定的目錄下查找要運行的類文獻.
還會在目前目錄找嗎?兩種狀況:
1):假如classpathH勺值結(jié)尾處有分號,在詳細途徑中沒有找到運行H勺類,會默認在目前目錄
再找一次。
2):假如classpath的值成果出沒有分號,在詳細的途徑中沒有找到運行口勺類,不會再目前目
錄找。
?股不指定分,I,假如沒有在指定目錄下找到要運行F、J類文獻,就報錯,這樣可以調(diào)試程序。
4,javac命令和java命令做什么事情呢?
要懂得java是分兩部分的:一種是編譯,一種是運行。
javac:負責(zé)的是編譯的部分,當執(zhí)行javac時,會后動java的編譯器程序。對指定擴展名
java文獻進行編譯。生成了jvm可以識別的字節(jié)碼文獻。也就是class文獻,也就是java的
運行程序。
java:負責(zé)運行的J部分.會啟動jvm.加載運行時所需的類庫,并對class文獻進行執(zhí)行.
一種文獻要被執(zhí)行,必須要有一種執(zhí)行日勺起始點,這個起始點就是main函數(shù).
當我在虛擬機中進行軟件評測時,也許系統(tǒng)同樣會瓦解,不過,瓦解日勺只是虛擬機上日勺操作系
統(tǒng),而不是物理計算機上H勺操作系統(tǒng),并且,使用虛擬機H勺“Undo”(恢復(fù))功能,我可以立即恢
復(fù)虛擬機到安裝軟件之前H勺狀態(tài)。
二:java語法基礎(chǔ):
1,關(guān)鍵字:其實就是某種語言賦予了特殊含義的單詞。
保留字:其實就是還沒有賦予特殊含義,不過準備后來要使用過的單詞。
2,標示符:其實就是在程序中自定義的名詞。例如類名,變量名,函數(shù)名。包括0-9,a-z、$、
一*9
注意:
1),數(shù)字不可以開頭。
2),不可以使用關(guān)鍵字。
3,常量:是在程序中的不會變化日勺數(shù)據(jù)。
4,變量:其實就是內(nèi)存中的一種存儲空間,用于存儲常量數(shù)據(jù)。
作用:以便于運算。由于有些數(shù)據(jù)不確定。因此確定該數(shù)據(jù)的名詞和存儲空間。
特點:變量空間可以反復(fù)使用。
什么時候定義變量?只要是數(shù)據(jù)不確定的時候,就定義變量。
變量空間的開辟需要什么要素呢?
1,這個空間要存儲什么數(shù)據(jù)?數(shù)據(jù)類型。
2,這個空間叫什么名字???變量名稱。
3,這個空間的第一次日勺數(shù)據(jù)是什么?變量的I初始化值。
變量的作用域和生存期:
變量的作用域:
作用域從變量定義H勺位置開始,到該變量所在的那對大括號結(jié)束;
生命周期;
變量從定義日勺位置開始就在內(nèi)存中活了;
變量抵達它所在的作用域的時候就在內(nèi)存中消失了;
數(shù)據(jù)類型:
1):基本數(shù)據(jù)類型:byte、shortNint>long、float、double、char>boolean
2):引用數(shù)據(jù)類型:數(shù)組、類、接口。
級別從低到高為:byte,char,short(這三個平級)一>int—>float—>long-->double
自動類型轉(zhuǎn)換:從低級別到高級別,系統(tǒng)自動轉(zhuǎn)的;
強制類型轉(zhuǎn)換:什么狀況下使用?把一種高級別的數(shù)賦給一種別該數(shù)的級別低日勺變量;
運算符號:
1)、算術(shù)運算符。
+-*/%%:任何整數(shù)模2不是0就是1,因此只要變化被模數(shù)就可以實現(xiàn)開關(guān)運算。
+:連接符。
++,一
2)、賦值運算符。
=+=-=*=/-%=
3)、比較運算符。
特點:該運算符的特點是:運算完『、J成果,要么是true,要么是false。
4)、邏輯運算符。
&|一!&&||
邏輯運算符除了!外都是用于連接兩個boolean類型體現(xiàn)式。
&:只有兩邊都為true成果是true。否則就是false。
I:只要兩邊都為false成果是false,否則就是true
N異或:和或有點不一樣樣。
兩邊成果同樣,就為false。
兩邊成果不一樣樣,就為true.
&和&&區(qū)別:&;無論左邊成果是什么,右邊都參與運算。
&&:短路與,假如左邊為false,那么右邊不參數(shù)與運算。
I和II區(qū)別:I:兩邊都運算。
II:短路或,假如左邊為true,那么右邊不參與運算。
5)、位運算符:用于操作二進制位日勺運算符.
&
??>>>(無符號右移)
練習(xí):對兩個變量的數(shù)據(jù)進行互換。不需要第三方變量。
inta=3,b=5;—>b=3,a=5;
a=a+b;a=8;
b=a-b;b=3;
a=a-b;a=5;
a=a'b;//
b=a-b;//b=a~b"b=a
a=a~b;//a=a'b~a=b;
練習(xí):高效IT、J算出2*8=2?3;
5,語句。
Ifswitchdowhilewhilefor
這些語句什么時候用?
1)、當判斷固定個數(shù)日勺值的時候,可以使用if,也可以使用switch。
不過提議使用switch,效率相對較高。
switch(變量){
case值:要執(zhí)行的語句;break;
default:要執(zhí)行的語句;
}
工作原理:用小括號中的變量H勺值依次和case背面日勺值進行對比,和哪個case背面時值相似了
就執(zhí)行哪個ease背面的語句,假如沒有相似日勺則執(zhí)行default,背面的語句;
細節(jié):1):break是可以省略的,假如省略了就一直執(zhí)行到碰到break為止;
2):switch背面『、J小括號中的I變量應(yīng)當是byte,char,short,int四種類型中日勺一種;
3):default可以寫在switch構(gòu)造中日勺任意位置;假如將default語句放在了第一行,則
不管expression與case中的value與否匹配,程序會從default開始執(zhí)行直到第一種break出
現(xiàn)。
2)、當判斷數(shù)據(jù)范圍,獲取判斷運算成果boolean類型時,需要使用if。
3)、當某些語句需要執(zhí)行諸多次時,就用循環(huán)構(gòu)造。
while和for可以進行互換,
區(qū)別在于:假如需要定義變量控制循環(huán)次數(shù)。提議使用for。由于for循環(huán)完畢,變量在內(nèi)存
中釋放。
break:作用于switch,和循環(huán)語句,用于跳出,或者稱為結(jié)束。
break語句單獨存在時,下面不要定義其他語句,由于執(zhí)行不到,編譯會失敗。當循環(huán)嵌套時,break
只跳出目前所在循環(huán)。要跳出嵌套中H勺外部循環(huán),只要給循環(huán)起名字即可,這個名字稱之為標號。
continue:只作用于循環(huán)構(gòu)造,雉續(xù)循環(huán)用的J。
作用:結(jié)束本次循環(huán),繼續(xù)下次循環(huán)。該語句單獨存在時,下面不可以定義語句,執(zhí)行不到。
6,函數(shù):為了提高代碼的復(fù)用性,可以將其定義成一種單獨的功能,該功能的體現(xiàn)就是java中
口勺函數(shù)。函數(shù)就是體現(xiàn)之一。
java中的函數(shù)的定義格式:
修飾符返回值類型函數(shù)名(參數(shù)類型形式參數(shù)L參數(shù)類型形式參數(shù)L…)(
執(zhí)行語句;
return返回值;
)
當函數(shù)沒有詳細H勺返回值時,返回的返回值類型用void關(guān)鍵字表達。
假如函數(shù)日勺返回值類型是void時?,rct.n語句可以省略不寫日勺,系統(tǒng)會幫你自動加上。
return的作用:結(jié)束函數(shù)。結(jié)束功能。
怎樣定義一種函數(shù)?
函數(shù)其實就是一種功能,定義函數(shù)就是實現(xiàn)功能,通過兩個明確來完畢:
1)、明確該功能口勺運算完的成果,其實是在明確這個函數(shù)的返回值類型。
2)、在實現(xiàn)該功能的過程中與否有未知內(nèi)容參與了運算,其實就是在明確這個函數(shù)的參數(shù)列表
(參數(shù)類型&參數(shù)個數(shù))。
函數(shù)的作用:
1)、用于定義功能。
2)、用于封裝代碼提高代碼日勺復(fù)用性。
注意:函數(shù)中只能調(diào)用函數(shù),不能定義函數(shù)。
主函數(shù):
1)、保證該類的獨立運行。
2)、由于它是程序的入口。
3)、由于它在被jvm調(diào)用。
函數(shù)定義名稱是為何呢?
答:I)、為了對該功能進行標示,以便于調(diào)用。
2)、為了通過名稱就可以明確函數(shù)的功能,為了增長代碼日勺閱讀性。
重載H勺定義是:在一種類中,假如出現(xiàn)了兩個或者兩個以上的I同名函數(shù),只要它們?nèi)丈讌?shù)的個數(shù),
或者參數(shù)日勺類型不一樣,即可稱之為該函數(shù)重載了。
怎樣辨別重載:當函數(shù)同名時,只看參數(shù)列表。和返回值類型沒關(guān)系。
7,數(shù)組:用于存儲同一類型數(shù)據(jù)口勺一種容器。好處:可以對該容器中日勺數(shù)據(jù)進行編號,從0開
始。數(shù)組用于封裝數(shù)據(jù),就是一種詳細的實體。
怎樣在java中體現(xiàn)一種數(shù)組呢?兩種體現(xiàn)形式。
1)、元素類型口變量名=new元素類型〔元素日勺個數(shù)];
2)、元素類型口變量名={元素1,元素2...};
元素類型口變量名二new元素類型□{元素1,元素2...};
〃二分查找法。必須有前提:數(shù)組中的元素要有序。
publicstaticinthalfSeach2(int[]arr,intkey){
intmin,max,mid;
min=0;
max=arr.length-1;
mid=(max+min)>>1;//(max+min)/2;
while(arr[mid]!=key){
if(key>arr[mid]){
min=mid+1;
}
elseif(kcy<arr[mid])
max=mid-1;
if(max<min)
return-1;
mid=(max+min)>>1;
returnmid;
}
java分了5片內(nèi)存。
1:寄存器。2:當?shù)卮胧﹨^(qū)。3:措施區(qū)。4:棧。5:堆。
棧:存儲的都是局部變量(函數(shù)中定義的變量,函數(shù)上的參數(shù),語句中H勺變量);
只要數(shù)據(jù)運算完畢所在的區(qū)域結(jié)束,該數(shù)據(jù)就會被釋放。
堆:用于存儲數(shù)組和對象,也就是實體。啥是實體???就是用于封裝多種數(shù)據(jù)的。
1:每一種實體均有內(nèi)存首地址值。
2:堆內(nèi)存中的變量均有默認初始化值。由于數(shù)據(jù)類型不一樣,值也不一樣樣。
3:垃圾回收機制。
三:面向?qū)ο螅骸铩铩铩铩?/p>
特點:1:將復(fù)雜的事情簡樸化,
2:面向?qū)ο髮⒋饲暗倪^程中的I執(zhí)行者,變成了指揮者。
3:面向?qū)ο筮@種思想是符合目前人們思索習(xí)慣的一種思想。
過程和對象在我們的程序中是怎樣體現(xiàn)的呢?過程其實就是函數(shù);對象是將函數(shù)等某些內(nèi)容進行了
封裝。
匿名對象使用場景:
1:當對措施只進行一次調(diào)用的時候,可以使用匿名對象。
2:當對象對組員進行多次調(diào)用時,不能使用匿名對象。必須給對象起名字。
在類中定義其實都稱之為組員。組員有兩種:
1:組員變量:其實對應(yīng)的就是事物H勺屬性。
2:組員函數(shù):其實對應(yīng)的就是事物H勺行為。
因此,其實定義類,就是在定義組員變量和組員函數(shù)。不過在定義前,必須先要對事物進行屬性和
行為日勺分析,才可以用代碼來體現(xiàn)。
privateintage;〃私有的訪問權(quán)限最低,只有在本類中的訪問有效。
注意:私有僅僅是封裝的一種體現(xiàn)形式而已。
私有的I組員;其他類不能直接創(chuàng)立對象訪問,因此只有通過本類對外提供詳細的訪問方式來完畢
對私有的訪問,可以通過對外提供函數(shù)的形式對其進行訪問。
好處:可以在函數(shù)中加入邏輯判斷等操作,對數(shù)據(jù)進行判斷等操作。
總結(jié):開發(fā)時,記住,屬性是用于存儲數(shù)據(jù)時,直接被訪問,輕易出現(xiàn)安全隱患,因此,類中的
屬性一般被私有化,并對外提供公共的訪問措施。
這個措施一般有兩個,規(guī)范寫法:對于屬性XXX,可以使用setXXX(),getXXX()對其進行操作。
類中怎么沒有定義主函數(shù)呢?
注意:主函數(shù)的存在,僅為該類與否需要獨立運行,假如不需要,主函數(shù)是不用定義的。
主函數(shù)的解釋:保證所在類的獨立運行,是程序的入口,被jvm調(diào)用。
組員變量和局部變量的區(qū)別:
1:組員變量直接定義在類中。
局部變量定義在措施中,參數(shù)上,語句中。
2:組員變量在這個類中有效。
局部變量只在自己所屬的大括號內(nèi)有效,大括號結(jié)束,局部變量失去作用域。
3:組員變量存在于堆內(nèi)存中,伴隨對象的產(chǎn)生而存在,消失而消失。
局部變量存在于棧內(nèi)存中,伴隨所屬區(qū)域的運行而存在,結(jié)束而釋放。
構(gòu)造函數(shù):用于給對象進行初始化,是給與之對應(yīng)的對象進行初始化,它具有針對性,函數(shù)中的一
種。
特點:
1:該函數(shù)的名稱和所在類的名稱相似。
2:不需要定義返回值類型,
3:該函數(shù)沒有詳細日勺返回值。
記住:所有對象創(chuàng)立時,都需要初始化才可以使用。
注意事項:一種類在定義時,假如沒有定義過構(gòu)造函數(shù),那么該類中會自動生成一種空參數(shù)的構(gòu)
造函數(shù),為了以便該類創(chuàng)立對象,完畢初始化。假如在類中自定義了構(gòu)造函數(shù),那么默認的構(gòu)造函
數(shù)就沒有了。
一種類中,可以有多種構(gòu)造函數(shù),由于它們口勺函數(shù)名稱都相似,因此只能通過參數(shù)列表來辨別。因
此,一種類中假如出現(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)造代碼塊:是給所有的對象進行初始化,也就是說,所有的對象都會調(diào)用一種代碼塊。只要
對象一建立。就會調(diào)用這個代碼塊。
構(gòu)造函數(shù):是給與之對應(yīng)的對象進行初始化。它具有針對性。
■rsonp=newPerson();
創(chuàng)立一種對象都在內(nèi)存中做了什么事情?
1:先將硬盤上指定位置的Person,class文獻加載進內(nèi)存。
2:執(zhí)行main措施時,在棧內(nèi)存中開辟了main措施日勺空間(壓棧-進棧),然后在main措施H勺
棧辨別配了一種變量P。
3:在堆內(nèi)存中開辟一種實體空間,分派了一種內(nèi)存首地址值。new
4:在該實體空間中進行屬性的空間分派,并進行了默認初始化。
5;對空間中時屬性進行顯示初始化。
6:進行實體日勺構(gòu)造代碼塊初始化。
7:調(diào)用該實體對應(yīng)的構(gòu)造函數(shù),進行構(gòu)造函數(shù)初始化。()
8:將首地址賦值給p,p變量就引用了該實體。(指向了該對象)
封裝(面向?qū)ο筇匦灾唬菏侵鸽[藏對象的屬性和實現(xiàn)細節(jié),僅對外提供公共訪問方式。
好處:將變化隔離;便于使用;提高重用性;安全性。
封裝原則:將不需要對外提供的內(nèi)容都隱藏起來,把屬性都隱藏,提供公共措施對其訪問。
this:代表對象。就是所在函數(shù)所屬對象的引用。
this究竟代表什么呢?哪個對象調(diào)用了this所在的函數(shù),this就代表哪個對象,就是哪個對象
的引用。
開發(fā)時,什么時候使用this呢?
在定義功能時,假如該功能內(nèi)部使用到了調(diào)用該功能的對象,這時就用this來表達這個對象。
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)對象中的I共性數(shù)據(jù)的對象共享??梢詫⑦@個數(shù)據(jù)進行靜態(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)修飾H勺。由于那樣的話,特有數(shù)據(jù)會變成對象
H勺共享數(shù)據(jù)。這樣對事物H勺描述就出了問題。因此,在定義靜態(tài)時,必須要明確,這個數(shù)據(jù)與否
是被對象所共享日勺。
2,靜態(tài)措施只能訪問靜態(tài)組員,不可以訪問非靜態(tài)組員。
(這句話是針對同一種類環(huán)境下『、J,例如說,i種類有多種組員(屬性,措施,字段),靜態(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ù)與否是所有對象都同樣:
假如是,那么物?量需要被靜態(tài)修飾,由于是共享的數(shù)據(jù)
假如不是,那么就說這是對象的特有數(shù)據(jù),要存儲到對象中。
2,組員函數(shù)。,.施中沒行調(diào)態(tài))
假如判斷組員函數(shù)與否需要被靜態(tài)修飾呢?
只要參照,該函數(shù)內(nèi)與否訪問了對象中的特有數(shù)據(jù):
假如有訪問特有數(shù)據(jù),那措施不能被靜態(tài)修飾。
假如沒有訪問過特有數(shù)據(jù),那么這個措施需要被靜態(tài)修飾C
組員變量和靜態(tài)變量的區(qū)別:
1,組員變量所屬于對象。因此也稱為實例變量。
靜態(tài)變量所屬于類。因此也稱為類變量。
2,組員變量存在于堆內(nèi)存中c
靜態(tài)變量存在于措施區(qū)中,
3,組員變量伴隨對象創(chuàng)立而存在。伴隨對象被回收而消失。
靜態(tài)變量伴隨類日勺加載而存在。伴隨類日勺消失面消失。
4,組員變量只能被對象所調(diào)用。
靜態(tài)變量可以被對象調(diào)用,也可以被類名調(diào)用。
因此,組員變量可以稱為對象的I特有數(shù)據(jù),靜態(tài)變量稱為對象的共享數(shù)據(jù)。
靜態(tài)的注意:靜態(tài)的生命周期很長。
靜態(tài)代碼塊:就是一種有靜態(tài)關(guān)鍵字標示的一種代碼塊區(qū)域。定義在類中。
作用:可以完畢類的初始化。靜態(tài)代碼塊伴隨類的加載而執(zhí)行,并且只執(zhí)行一次(new多種對象
就只執(zhí)行一次)。假如和主函數(shù)在同一類中,優(yōu)先于主函數(shù)執(zhí)行。
Public:訪問權(quán)限最大。
static:不需要對象,直接類名即可。
void:主函數(shù)沒有返回值。
Main;主函數(shù)特定的名稱。
(String[]args):主函數(shù)的I參數(shù),是一種字符串數(shù)組類型日勺參數(shù),jvm調(diào)用main措施時,傳遞的
實際參數(shù)是newString[0]o
jvm默認傳遞的是長度為0歐I字符串數(shù)組,我們在運行該類時,也可以指定詳細的參數(shù)進行傳遞。
可以在控制臺,運行該類時,在背面加入?yún)?shù)。參數(shù)之間通過空格隔開。jvm會自動將這些字符串
參數(shù)作為args數(shù)組中的元素,進行存儲。
靜態(tài)代碼塊、構(gòu)造代碼塊、構(gòu)造函數(shù)同步存在時時執(zhí)行次序:靜態(tài)代碼塊分構(gòu)造代碼塊今構(gòu)
造措施;
生成Java協(xié)助文檔:命令格式:javadoc-d文獻夾名-auther-versionjava
/**〃格式
*類描述
*@author作者名
Aversion版本號
*/
/**
*措施描述
*@param參數(shù)描述
*@return返回值描述
*/
設(shè)計模式:處理問題最行之有效日勺思想。是一套被反復(fù)使用、多數(shù)人知曉日勺、通過度類編目的I、代
碼設(shè)計經(jīng)驗的總結(jié)。使用設(shè)計模式是為了可重用代碼、讓代碼更輕易被他人理解、保證代碼可靠性。
java中有23種設(shè)計模式:
單例設(shè)計模式:★★★★★
處理H勺問題:保證一種類在內(nèi)存中的對象唯一性。
例如:多程序讀取一種配置文獻時,提議配置文獻封裝成對象。會以便操作其中數(shù)據(jù),又要保證多
種程序讀到時是同一種配置文獻對象,就需要該配置文獻對象在內(nèi)存中是唯一日勺。
Runtime()措施就是單例設(shè)計模式進行設(shè)計的。
怎樣保證對象唯一性呢?
思想:
1,不讓其他程序創(chuàng)立該類對象。
2,在本類中創(chuàng)立一種本類對象。
3,對外提供措施,讓其他程序獲取這個對象。
環(huán)節(jié):
b由于創(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(
privateSingleO{}//私有化構(gòu)造函數(shù)。
privatestaticSingles=nawSinglA();//創(chuàng)立私有并靜態(tài)的本類對象。
publicstaticSinglegetTnstance(){//定義公有并靜態(tài)的措施,返回該對象。
returns;
}
〃懶漢式:延遲加載方式。
classSingle2{
privateSingle2(){)
privatestaticSingle2s=null;
publicstaticSingle2getInstance(){
if(s==null)
s=newSingle2();
returns;
)
}
繼承(面向?qū)ο筇匦灾唬?/p>
好處:
1:提高了代碼的復(fù)用性。
2:讓類與類之間產(chǎn)生了關(guān)系,提供了另一種特性多態(tài)的前提。
父類H勺由來:其實是由多種類不停向上抽取共性內(nèi)容而來日勺。
java中對于繼承,java只支持單繼承。java雖然不直接支持多繼承,不過保留了這種多繼承機制,
進行改良。
單繼承:一種類只能有一種父類。
多繼承:一種類可以有多種父類。
為何不支持多繼承呢?
由于當一種類同步繼承兩個父類時,兩個父類中有相似的功能,那么子類對象調(diào)用該功能時,
運行哪一種呢?由于父類中的措施中存在措施體。
不過java支持多重繼承。A繼承BB繼承CC繼承D。
多重繼承日勺出現(xiàn),就有了繼承體系。體系中的頂層父類是通過不停向上抽取而來的。它里面定
義的該體系最基本最共性內(nèi)容日勺功能。
因此,一種體系要想被使用,直接查閱該系統(tǒng)中的父類H勺功能即可懂得該體系H勺基本使用方法。
那么想要使用一種體系時,需要建立對象。k議建4,由于最子類不僅可以使用父類中
口勺功能。還可以使用子類特有口勺某些功能。
簡樸說:對于一種繼承體系的使用,查閱頂層父類中的內(nèi)容,創(chuàng)立最底層子類的對象。
子父類出現(xiàn)后,類中的組員均有了哪些特點:
1:組員變量。
當子父類中出現(xiàn)同樣附屬性時,子類類型的對象,調(diào)用該屬性,值是子類的屬性值。
假如想要調(diào)用父類中啊屬性值,需要使用一種關(guān)鍵字:super
This:代表是本類類型的對象引用。
Super:代表是子類所屬的父類中的內(nèi)存空間引用。
注意:子父類中一般是不會出現(xiàn)同名組員變量的,由于父類中只要定義了,子類就不用在定
義了,直接繼承過來用就可以了。
2:組員函數(shù)。
當子父類中出現(xiàn)了一模同樣的措施時,建立子類對象會運行子類中的措施。仿佛父類中H勺措施
被覆蓋掉同樣。因此這種狀況,是函數(shù)的另一種特性:覆蓋(復(fù)寫,重寫)
什么時候使用覆蓋呢?當一種類的功能內(nèi)容需要修改時,可以通過覆蓋來實現(xiàn)。
3:構(gòu)造函數(shù)。
發(fā)現(xiàn)子類構(gòu)造函數(shù)運行時,先運行了父類日勺構(gòu)造函數(shù)。為何呢?
原因:子類日勺所有構(gòu)造函數(shù)中的第一行,其實均有一條隱身的I語句superO;
super():表達父類日勺構(gòu)造函數(shù),并會調(diào)用于參數(shù)相對應(yīng)日勺父類中日勺構(gòu)造函數(shù)。而super。:是
在調(diào)用父類中空參數(shù)日勺構(gòu)造函數(shù)。
為何子類對象初始化時,都需要調(diào)用父類中的函數(shù)?(為何要在子類構(gòu)造函數(shù)的第一行加入這
個super()?)
由于子類繼承父類,會繼承到父類中的數(shù)據(jù),因此必須要看父類是怎樣對自己的數(shù)據(jù)進行初始
化,口此」「象",先調(diào)用父類的構(gòu)造函數(shù),這就是子類的實例化過程。
注意:子類中所有的構(gòu)造函數(shù)都會默認訪問父類中時空參數(shù)的構(gòu)造函數(shù),由于每一種子類構(gòu)
造內(nèi)第一行均有默認的語句super();
假如父類中沒有空參數(shù)的構(gòu)造函數(shù),那么子類的I構(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?;蛘遲his。都是調(diào)用構(gòu)造函數(shù),構(gòu)造函數(shù)用于初始化,因此初始化的動作要先完
畢。
繼承的細節(jié):
什么時候使用繼承呢?
當類與類之間存在著所屬關(guān)系時,才具有了繼承的前提。a是b中的一種。a繼承b。狼是犬
科中日勺一種。
英文書中,所屬關(guān)系:〃isa”
注意:不要僅僅為了獲取其他類中的己經(jīng)有組員進行繼承。
因此判斷所屬關(guān)系,可以簡樸看,假如繼承后,被繼承的類中的功能,都可以被該子類所具
有,那么繼承成立。假如不是,不可以繼承。
細節(jié)二:
在措施覆蓋時,注意兩點:
1:子類覆蓋父類時,必須要保證,子類措施的權(quán)限必須不小于等于父類措施權(quán)限可以實現(xiàn)繼
承。否則,編譯失敗。
2:覆蓋時,要么都靜態(tài),要么都不靜態(tài)。(靜態(tài)只能覆蓋靜態(tài),或者被靜態(tài)覆蓋)
繼承H勺一種弊端:打破了封裝性。對于某些類,或者類中功能,是需要被繼承,或者復(fù)寫的。
這時怎樣處理問題呢?簡介一種關(guān)鍵字,final:最終。
final特點:
1:這個關(guān)鍵字是一種修飾符,可以修飾類,措施,變量。
2:被final修飾的類是一種最終類,不可以被繼承。
3:被final修飾的措施是一種最終措施,不可以被覆蓋。
4:被final修飾的|變量是一種常量,只能賦值一次。
其實這樣的原因的就是給某些固定的數(shù)據(jù)起個閱讀性較強H勺名稱。
不加final修飾不是也可以使用嗎?那么這個值是一種變量,是可以更改時。加了final,程
序更為嚴謹。常量名稱定義時,有規(guī)范,所有字母都大寫,假如由多種單詞構(gòu)成,中間用_連接。
抽象類:abstract
抽象:不詳細,看不明白。抽象類表象體現(xiàn)。
在不停抽取過程中,將共性內(nèi)容中H勺措施申明抽取,不過措施不一樣樣,沒有抽取,這時抽取
到的措施,并不詳細,需要被指定關(guān)鍵字abstract所標示,申明為抽象措施。
抽象措施所在類一定要標示為抽象類,也就是說該類需要被abstract關(guān)鍵字所修飾。
抽象類的特點:
1:抽象措施只能定義在抽象類中,抽象類和抽象措施必須由abstract關(guān)鍵字修飾(可以描
述類和措施,不可以描述變量),
2:抽象措施只定義措施申明,并不定義措施實現(xiàn)。
3:抽象類不可以被創(chuàng)立對象(實例化)。
4:只有通過子類繼承抽象類并覆蓋了抽象類中的所有抽象措施后,該子類才可以實例化。否
則,該子類還是一種抽象類。
抽象類的細節(jié):
1:抽象類中與否有構(gòu)造函數(shù)?有,用于給子類對象進行初始化。
2:抽象類中與否可以定義非抽象措施?
可以。其實,抽象類和一般類沒有太大的區(qū)別,都是在描述事物,只不過抽象類在描述事物時,
有些功能不詳細。因此抽象類和一般類在定義上,都是需要定義屬性和行為的。只不過,比一般類
多了一種抽象函數(shù)。并且比一般類少了一種創(chuàng)立對象的I部分。
3:抽象關(guān)鍵字abstract和哪些不可以共存?final,private,static
4:抽象類中可不可以不定義抽象措施?可以。抽象措施目的僅僅為了不讓該類創(chuàng)立對象。
模板措施設(shè)計模式:
處理日勺問題:當功能內(nèi)部一部分實現(xiàn)時確定,一部分實現(xiàn)是不確定日勺。這時可以把不確定的部分暴
露出去,讓子類去實現(xiàn)。
abstractclassGetTime(
publicfinalvoidgetTiire(){〃此功能假如不需要復(fù)寫,可加final限定
longstart=System.currentTimeMillis();
code();〃不確定的I功能部分,提取出來,通過抽象措施實現(xiàn)
longend二System.currentTimeMi11is();
System,out.printin("毫秒是:(end-start));
}
publicabstractvoidcode();〃抽象不確定歐J功能,讓子類復(fù)寫實現(xiàn)
)
classSubDemoextendsGetTime{
publicvoidcode(){〃子類復(fù)寫功能措施
for(inty=0;y<1000;y++){
System.out.println(〃y〃);
}
)
接口:★★★★★
1:是用關(guān)鍵字interface定義的。
2:接口中包括日勺組員,最常見日勺有全局常量、抽象措施。
注意:接口中的組員均有固定日勺修飾符。
組員變量:publicstaticfinal
組員措施:publicabstract
interfaceInter{
publicstaticfinalintx=3;
publicabstractvoidshow();
}
3:接口中有抽象措施,闡明接口不可以實例化。接口的子類必須實現(xiàn)了接口中所有的抽象措施后,
該子類才可以實例化。否則,該子類還是一種抽象類。
4:類與類之間存在著繼承關(guān)系,類與接口中間存在日勺是實現(xiàn)關(guān)系。
繼承用extends;實現(xiàn)用implements;
5:接口和類不一樣樣的地方,就是,接口可以被多實現(xiàn),這就是多繼承改良后日勺成果。java將多
繼承機制通過多現(xiàn)實來體現(xiàn)。
6:一種類在繼承另一種類H勺同步,還可以實現(xiàn)多種接口。因此接口的出現(xiàn)防止了單繼承的局限性。
還可以將類進行功能H勺擴展。
7:其實java中是有多繼承的。接口與接口之間存在著繼承關(guān)系,接口可以多繼承接口。
接口都用于設(shè)計上,設(shè)計上的特點:(可以理解主板上提供日勺接口)
1:接口是對外提供的規(guī)則。
2:接口是功能的I擴展。
3:接口的出現(xiàn)減少了耦合性。
抽象類與接口:
抽象類:一般用于描述一種體系單元,將一組共性內(nèi)容進行抽取,特點:可以在類中定義抽象內(nèi)容
讓子類實現(xiàn),可以定義非抽象內(nèi)容讓子類直接使用。它里面定義時都是某些體系中日勺基本內(nèi)容。
接口:一般用于定義對象日勺擴展功能,是在繼承之外還需這個對象具有的某些功能。
抽象類和接口的共性:都是不停向上抽取的成果。
抽象類和接口的區(qū)別:
1:抽象類只能被繼承,并且只能單繼承。
接口需要被實現(xiàn),并且可以多實現(xiàn)。
2:抽象類中可以定義非抽象措施,子類可以直接繼承使用。
接口中都是抽象措施,需要子類去實現(xiàn)。
3:抽象類使用的是isa關(guān)系。
接口使用的likea關(guān)系。
4:抽象類的組員修飾符可以自定義。
接口中的組員修飾符是固定的。全都是public的。
在開發(fā)之前,先定義規(guī)則,A和B分別開發(fā),A負責(zé)實現(xiàn)這個規(guī)則,B負責(zé)使用這個規(guī)則。至
于A是怎樣對規(guī)則詳細實現(xiàn)的,B是不需要懂得的。這樣這個接口的出現(xiàn)就減少了A和B直接耦合
性。
多(面向?qū)ο筇匦灾?:函數(shù)自身就具有多態(tài)性,某一種事物有不一樣的詳細的
體現(xiàn)。
體現(xiàn):父類引用或者接口時引用指向了自己的子類對象?!ˋnimala=newCat();父類可以調(diào)用
子類中覆寫過日勺(父類中有的措施)
多態(tài)的好處:提高了程序的擴展性。繼承的父類或接口一般是類庫中的東西,(假如要修改某個措
施的詳細實現(xiàn)方式)只有通過子類去覆寫要變化的某一種措施,這樣在通過將父類的應(yīng)用指向子
類的實例去調(diào)用覆寫過的措施就行了!
多態(tài)的弊端:當父類引用指向子類對象時,雖然提高了擴展性,不過只能訪問父類中具有的I措施,
不可以訪問子類中特有的1措施。(前期不能使用后期產(chǎn)生的功能,即訪問H勺局限性)
多態(tài)的前提:
1:必須要有關(guān)系,例如繼承、或者實現(xiàn)。
2:一般會有覆蓋操作。
多態(tài)的出現(xiàn)思想上也做著變化:此前是創(chuàng)立對象并指揮對象做事情。有了多態(tài)后來,我們可以找
到對象的共性類型,直接操作共性類型做事情即可,這樣可以指揮一批對象做事情,即通過操作父
類或接口實現(xiàn)。
class畢姥爺{
void講課(){
System.out.printin(〃企業(yè)管理〃);
)
void釣魚(){
System,out.printin("釣魚〃);
)
)
class畢老師extends畢姥爺{
void講課(){
System.out.printin(〃JAVA〃);
)
void看電影0{
System.out.printin(〃看電影〃);
)
)
class{
publicstaticvoidmain(String[]args){
畢姥爺x二new畢老師();〃畢老師對象被提高為了畢姥爺類型。
//x.講課0;
//X.看電影0;〃錯誤.
畢老師y=(畢老師)X;〃將畢姥爺類型強制轉(zhuǎn)換成畢老師類型。
.在今態(tài)中,自始自終都是子類對象在做著類型的變化。
)
假如想用子類對象的特有措施,怎樣判斷對象是哪個詳細的子類類型呢?
可以可以通過一種關(guān)鍵字instanccof;〃判斷對象與否實現(xiàn)了指定的接口或繼承了指定的類
格式:〈對象instanceof類型〉,判斷一種對象與否所屬于指定區(qū)I類型。
StudentinstanceofPerson=true"/student繼承了person類
多態(tài)在子父類中的組員上時體現(xiàn)的特點:
1,組員變量:在多態(tài)中,子父類組員變量同名。
在編譯時期:參照時是引用型變量所屬的類中與否有調(diào)用日勺組員。(編譯時不產(chǎn)生對象,只檢
查語法錯誤)
運行時期:也是參照引用型變量所屬的類中與否有調(diào)用的組員。
簡樸一句話:無論編譯和運行,組員變量參照的都是引用變量所屬的類中的組員變量。
再說日勺更輕易記憶某些:組員變量--編譯運行都看二左邊。
2,組員函數(shù)。
編譯時期:參照引用型變量所屬H勺類中與否有調(diào)用的措施。
運行事情:參照口勺是對象所屬的類中與否有調(diào)用口勺措施。
為何是這樣的呢?由于在子父類中,對于一模同樣的組員函數(shù),有一種特性:覆蓋。
簡樸一句:組員函數(shù),編譯看引用型變量所屬的類,運行看對象所屬的類。
更簡樸:組員函數(shù)---編譯看=左邊,運行看=右邊。
3,靜態(tài)函數(shù)。
編譯時期:參照日勺是引用型變量所屬日勺類中與否有調(diào)用的組員。
運行時期:也是參照引用型變量所屬日勺類中與否有調(diào)用時組員。
為何是這樣的呢?由于靜態(tài)措施,其實不所屬于對象,而是所屬于該措施所在的類。
調(diào)用靜態(tài)的措施引用是哪個類的引用調(diào)用日勺就是哪個類中H勺靜態(tài)措施。
簡樸說:靜態(tài)函數(shù)--編譯運行都看=左邊。
Object:所有類的直接或者間接父類,Java認為所有日勺對象都具有某些基本的共性內(nèi)容,這些內(nèi)
容可以不停的向上抽取,最終就抽取到了一種最頂層日勺類中的),該類中定義日勺就是所有對象都具有
日勺功能。
詳細措施:
Lbooleanequals(Objectobj):用于比較兩個對象與否相等,其實內(nèi)部比較的就是兩個對象
地址。假如根據(jù)equals(Object)措施,兩個對象是相等的,那么對這兩個對象中的每個對象
調(diào)用hashCode措施都必須生成相似的整數(shù)成果;
而根據(jù)對象的屬性不一樣,判斷對象與否相似的詳細內(nèi)容也不一樣樣。因此在定義類時,一般都
會復(fù)寫equals措施,建立本類特有的判斷對象與否相似的根據(jù)。
publicbooleanequals(Objectobj){
if(!(objinstanceofPerson))
returnfalse;
Personp=(Person)obj;
returnthis,age==p.age;
)
2,StringtoStringO:籽對象變成字符串;默認返回H勺格式:類名@哈希值=
getClass().getName()+'@'+Integer.toHexSlring(hashCode())
為了對象對應(yīng)in字符串內(nèi)容故意義,可以通過復(fù)寫,建立該類對象自己特有的字符串體現(xiàn)形式。
publicStringtoStringO{
return'person:〃+ag。;
)
3,ClassgetClassO:獲取任意對象運行時日勺所屬字節(jié)碼文獻對象。
4,inthashCode():返回該對象H勺哈希碼值。支持此措施是為了提高哈希表的性能。將該對象
的內(nèi)部地址轉(zhuǎn)換成一種整數(shù)來實現(xiàn)的。
一般equals,toString,hashCode,在應(yīng)用中都會被復(fù)寫,建立詳細對象的特有的I內(nèi)容。
內(nèi)部類:假如A類需要直接訪問B類中的組員,而B類又需要建立A類的對象。這時,為了以便設(shè)
計和訪問,直接將A類定義在B類中。就可以了。A類就稱為內(nèi)部類。?部類可以?接訪問外部類
中的組員.而外部類想要訪問內(nèi)部類,必須要建立內(nèi)部類日勺對象。
classOuter{
intnum=4;
classInner{
voidshow(){
System,out.printin(^innershowrun"+num);
}
)
publicvoidmethod(){
Innerin=newInner。;〃創(chuàng)立內(nèi)部類的|對象。
in.show。;〃調(diào)用內(nèi)部類的措施?!▋?nèi)部類直接訪問外部類組員,用自己的實例對象;
}〃外部類訪問內(nèi)部類要定義內(nèi)部類的對象;
當內(nèi)部類定義在外部類中的組員位置上,可以使用某些組員修飾符修飾private、static。
1:默認修飾符。
直接訪問內(nèi)部類格式:外部類名.內(nèi)部類名變量名=外部類對象.內(nèi)部類對象;
Outer.Innerin=newOuter,newInner();〃這種形式很少用。
不過這種應(yīng)用不多見,由于內(nèi)部類之因此定義在內(nèi)部就是為了封裝。想要獲取內(nèi)部類對象一般
都通過外部類的措施來獲取。這樣可以對內(nèi)部類對象進行控制。
2:私有修飾符。
一般內(nèi)部類被封裝,都會被私有化,由于封裝性不讓其他程序直接訪問。
3:靜態(tài)修飾符。
假如內(nèi)部類被靜態(tài)修飾,相稱于外部類,會出現(xiàn)訪問局限性,只能訪問外部類中H勺靜態(tài)組員。
注意;假如內(nèi)部類中定義了靜態(tài)組員,那么該內(nèi)部類必須是靜態(tài)的。
內(nèi)部類編譯后的文獻名為:“外部類名$內(nèi)部類名.java”;
為何內(nèi)部類可以直接訪問外部類中的組員呢?
那是由于內(nèi)部中都持有一種外部類的引用。這個是引用是外部類名.this
內(nèi)部類可以定義在外部類中的組員位置上,也可以定義在外部類中的局部位置上。
當內(nèi)部類被定義在局部位置上,只能訪問局部中被final修飾的局部變量。
匿名內(nèi)部類(對象):沒有名字的內(nèi)部類。就是內(nèi)部類日勺簡化形式。一般只用一次就可以用這種形
式。匿名內(nèi)部類其實就是一種匿名子類對象。想要定義匿名內(nèi)部類:需要前提,內(nèi)部類必須繼承
一種類或者實現(xiàn)接口。
匿名內(nèi)部類的格式:new父類名&接口名(){定義子類組員或者覆蓋父類措施}.措施。
匿名內(nèi)部類的使用場景:
當函數(shù)的參數(shù)是接口類型引用時,假如接口中的措施不超過3個??梢酝ㄟ^匿名內(nèi)部類來完畢
參數(shù)口勺傳遞。
其實就是在創(chuàng)立匿名內(nèi)部類時,該類中的封裝日勺措施不要過多,最佳兩個或者兩個以內(nèi)。
〃面試
//I
newObject(){
voidshow(){
System.out.printIn(''showrun");
)
J.showO;〃寫法和編譯都沒問題
//2
Objectobj=newObject(){
voidshow(){
System.out.printin("showrun");
)
};
obj.show();〃寫法對的,編譯會報錯
1和2H勺寫法對的嗎?有區(qū)別嗎?說出原因。
寫法是對的,1和2都是在通過匿名內(nèi)部類建立一種Object類的子類對象。
區(qū)別;
第一種可是編譯通過,并運行。
第二個編譯失敗,由于匿名內(nèi)部類是一種子類對象,當用Object的obj引用指向時,就被
提高為了Object類型,而編譯時檢查Object類中與否有show措施,因此編譯失敗。
classlnnerClassDemo6{
+(static)classInner(
voidshow(){}
)
publicvoidmethod(){
this,newInner().show。;〃可以
)
publicstaticvoidmain(String[]args){"static不容許this
This,newInner().show。;〃錯誤,Inner類需要定義成static
)
}
interfaceInter{
voidshow();
)
classOuter{〃通過匿名內(nèi)部類補足Outer類中的代碼。
publicstaticIntermethod(){〃返回Inter類型的變量;
returnnewInter(){
publicvoidshow(){}
};
)
)
classTnriArClassD?mo7{
publicstaticvoidmain(String[]args){
Outer,method().show();
/*
Outer,method。:意思是:Outer中有一種名稱為method日勺措施,并且這個措施是靜態(tài)日勺。
Outer,method。,show。:當Outer類調(diào)用靜態(tài)的Imethod措施運算結(jié)束后歐I成果又調(diào)用了
show措施,意味著:method。措施運算完一種是對象,并且這個對象是Inter類型日勺。
*/
function(newInter(){
publicvoidshow(){}
));〃匿名內(nèi)部類作為措施的參數(shù)進行傳遞。
)
publicstaticvoidfunction(Interin){
in.show();
}
異常:★★★★
異常;就是不正常。程序在運行時出現(xiàn)口勺不正常狀況。其實就是程序中出現(xiàn)的問題。這個問題
按照面向?qū)ο笏枷脒M行描述,并封裝成了對象。由于問題向產(chǎn)生有產(chǎn)生的原因、有問題的名稱、有
問題的描述等多種屬性信息存在。當出現(xiàn)多屬性信息最以便向方式就是將這些信息進行封裝。異常
就是java按照面向?qū)ο蟮乃枷雽栴}進行對象封裝。這樣就以便于操作問題以及處理問題。
出現(xiàn)H勺問題有諸多種,例如角標越界,空指針等都是。就對這些問題進行分類。并且這些問題
均有共性內(nèi)容例如:每一種問題均有名稱,同步尚有問題描述的信息,問題出現(xiàn)的位置,因此可以
不停口勺向上抽取。形成了異常體系。
Throwable:可拋出H勺。
|-Error:錯誤,一般狀況下,不編寫針對性的代碼進行處理,一般是jvm發(fā)生的,需要對程
序進行修正。
I—Exception:異常,可以有針對性口勺處理方式
無論是錯誤還是異常,它們均有詳細的子類體現(xiàn)每一種問題,它們的子類均有一種共性,就是都以
父類名才作為子類的后綴名。
這個體系中的所有類和對象都具有一種獨有的特點;就是可拋性。
可拋性的體現(xiàn):就是這個體系中日勺類和對象都可以被throws和throw兩個關(guān)鍵字所操作。
classExceptionDemo(
publicstaticvoidmain(String[]args){
//byte[]buf=newbyte[1024*1024*700];內(nèi)存溢出錯誤
}
在開發(fā)時,假如定義功能時,發(fā)現(xiàn)該功能會出現(xiàn)某些問題,應(yīng)當將問題在定義功能時標示出
來,這樣調(diào)用者就可以在使用這個功能的時候,預(yù)先給出處理方式。
怎樣標示呢?通過throws關(guān)鍵字完畢,格式:throws異常類名,異常類名...
這樣標示后,調(diào)用者,在使用該功能時,就必須要處理,否則編譯失敗。
處理方式有兩種:1、捕捉;2、拋出。
對于捕捉:java有針對性日勺語句塊進行處理。
try{
需要被檢測的代碼;
)
catch(異常類變量名){
異常處理代碼;
)
fianlly{
一定會執(zhí)行的代碼;
)
catch(Exceptione){〃e用于接受by檢測到的異常對象。
System.out.printin(z/message:z,+e.getMessage())"/獲取的是異??谏仔畔ⅰ?/p>
System.out.printin("loString:〃+e.toStringO);//獲取/、J是異常Ff'J名字+異常/、J信息。
e.prinlStackTraceO;〃打印異常在堆棧中信息;異常名稱+異常信息+異常的位置。
異常處理原則:功能拋出幾種異常,功能調(diào)用假如進行try處理,需要與之對應(yīng)的catch處理代
碼塊,這樣的處理有針對性,拋幾種就處理幾種。
特殊狀況:對應(yīng)多種catch時,假如有父類的catch語句塊,一定要放在下面。
throw和throws關(guān)鍵字的區(qū)別:
throw用于拋出異常對象,背面跟的是異常對象;throw用在函數(shù)內(nèi)。
throws用于拋出異常類,背面跟歐I異常類名,可以跟多種,用逗號隔開。throws用在函數(shù)上。
一般狀況:函數(shù)內(nèi)容假如有throw,拋出異常對象,并沒有進行處理,那么函數(shù)上一定要申明,否
則編譯失敗。不過也有特殊狀況。
異常分兩種:
1:編譯時被檢查日勺異常,只要是Exception及其子類都是編譯時被檢測的異常。
2:運行時異常,其中Exception有一種特殊的子類Runtim中xception,以及RuntimeException
H勺子類是運行異常,也就說這個異常是編譯時不被檢查的異常。
編譯時被檢查的異常和運行時異常的區(qū)別:
編譯被檢查日勺異常在函數(shù)內(nèi)被拋出,函數(shù)必須要申明,否編譯失敗。
申明的原因:是需要調(diào)用者對該異常進行處理。
運行時異常假如在函數(shù)內(nèi)被拋出,在函數(shù)上不需要申明。
不申明日勺原因:不需要調(diào)用者處理,運行時異常發(fā)生,已經(jīng)無法再讓程序繼續(xù)運行,因此,不讓
調(diào)用處理日勺,直接讓程序停止,由調(diào)用者對代碼進行修正。
定義異常處理時,什么時候定義try,什么時候定義throws呢?
功能內(nèi)部假如出現(xiàn)異常,假如內(nèi)部可以處理,就用try;
假如功能內(nèi)部處理不了,就必須申明出來,讓調(diào)用者處理。使用throws拋出,交給調(diào)用者處理。
誰調(diào)用了這個功能誰就是調(diào)用者;
自定義異常:當開發(fā)時,項目中出現(xiàn)了java中沒有定義過的問題時,這時就需要我們按照java
異常建立思想,將項目的中的特有問題也進行對象日勺封裝。這個異常,稱為自定義異常。
對于除法運算,0作為除數(shù)是不可以的。java中對這種問題用ArithmeticException類進行描
述。對于這個功能,在我們項目中,除數(shù)除了不可認為0外,還不可認為負數(shù)??墒秦摂?shù)的部分
java并沒有針對描述。因此我們就需要自定義這個異常。
自定義異常的環(huán)節(jié):
1:定義一種子類繼承Exception或RuntimeException,讓該類具有可拋性(既可以使用throw
和throws去調(diào)用此類)。
2:通過throw或者throws進行操作。
異常的轉(zhuǎn)換思想:當出現(xiàn)的異常是調(diào)用者處理不了的,就需要將此異常轉(zhuǎn)換為一種調(diào)用者可以處
理時異常拋出。
trycatchfinally的幾種結(jié)合方式:
1,2.3,
try
catch
finally
這種狀況,假如出現(xiàn)異常,并不處理,不過資源一定關(guān)閉,因此tryfinally集合只為關(guān)閉資源。
記?。篺inally很有用,重要顧客關(guān)閉資源。無論與否發(fā)生異常,資源都必須進行關(guān)閉。
System,exit(0);〃退出jvm,只有這種狀況finally不執(zhí)行。
當異常出現(xiàn)后,在子父類進行覆蓋時,有了某些新的特點:
1:當子類覆蓋父類的措施時,假如父類的措施拋出了異常’,那么子類的措施要么不拋出異常要
么拋出父類異?;蛘咴摦惓5淖宇?,不能拋出其他異常。
2:假如父類拋出了多種異常,那么子類在覆蓋時只能抽出父類日勺異常的子集。
注意:
假如父類或者接口中的措施沒有拋出過異常,那么子類是不可以拋出異常時,假如子類的覆
蓋的措施中出現(xiàn)了異常,只能try不能throws。
假如這個異常子類無法處理,己經(jīng)影響了子類措施的詳細運算,這時可以在子類措施中,通
過throw拋出RuntimeException異常或者其子類,這樣,子類的措施上是不需要throws申明的。
常見異常:
1、腳標越界異常(IndexOutOfBoundsException)包括數(shù)組、字符串;
空指針異常(NullPointerException)
2、類型轉(zhuǎn)換異常:ClassCastExceprion
3、沒有這個元素異常:Nul1PointerException
4、不支持操作異常;
異常要盡量防止,假如防止不了,需要預(yù)先給出處理方式。例如家庭備藥,例如滅火器。
包:定義包用package關(guān)鍵字。
1:對類文獻進行分類管理。
2:給類文獻提供多層名稱空間G
銀如生成日勺包不在目前目錄下,需要最佳執(zhí)行classpath,將包所在父目錄定義到classpath
變量中即可。
一般在定義包名時,由于包的出現(xiàn)是為了辨別重名日勺類。因此包名要盡量唯一。怎么保證唯一
性呢?可以使用url域名來進行包名稱的定義。
packagepack;〃定義了一種包,名稱為pack。注意:包名的寫法規(guī)范:所有字母都小寫。
//packagecn.itcast.pack,demo;
類的全名稱是包名.類名
編譯命令:javac-d位置(.目前途徑)java源文獻(就可以自動生成包)
包是一種封裝形式,用于封裝類,想要被包以外的程序訪問,該類必須public;
類中日勺組員,假如被包以外訪問,也必須public;
包與包之間訪問可以使用的權(quán)限有兩種:
1:public
2:protected:只能是不一,樣包中的I子類可以使用的J權(quán)限。
總結(jié)java中的四種權(quán)限:
范圍publicprotecteddefaultprivate
同一種類中okokokok
同
溫馨提示
- 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)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 工程對賭協(xié)議書
- 建筑輔材合同范本
- 自愿購書協(xié)議書
- 小賣鋪合同協(xié)議
- 征收林地協(xié)議書
- 裝修財產(chǎn)協(xié)議書
- 我國京都協(xié)議書
- 裝修勞動協(xié)議書
- 蝦池承包協(xié)議書
- 裝修管道協(xié)議書
- MT/T 1218-2024煤礦動壓巷道水力壓裂切頂卸壓施工技術(shù)規(guī)范
- 中醫(yī)推拿知識培訓(xùn)課件
- 河道水管搶修方案(3篇)
- 沃柑種植合同協(xié)議書
- 河南省許昌市2024-2025學(xué)年八年級上學(xué)期數(shù)學(xué)期末測評卷(含答案與解析)
- 2024-2025學(xué)年四川省成都市高一上學(xué)期期末教學(xué)質(zhì)量監(jiān)測英語試題(解析版)
- 人生中的轉(zhuǎn)折點主題班會
- 陳景潤數(shù)學(xué)家人物介紹
- 【浙教版】一年級上冊《勞動》《水培植物我養(yǎng)護》
- 2024秋期國家開放大學(xué)本科《國際經(jīng)濟法》一平臺在線形考(形考任務(wù)1至4)試題及答案
- 醫(yī)學(xué)倫理學(xué)(山東中醫(yī)藥大學(xué))智慧樹知到答案2024年山東中醫(yī)藥大學(xué)
評論
0/150
提交評論