版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
方法,和對象。:-----------------------------------------------------------------------------------------------JAVAEE:JavaPlatformEnterpriseEdition,開發(fā)企業(yè)環(huán)境JAVASE:JavaPlatformStandardEdition,完成桌面應(yīng)用程2,JRE:JavaRuntimeEnvironment,java程序的運行環(huán)境,java運行的所需的類庫+JVM(java虛擬機)。目錄下運行,原因是,將該工具所在目錄告訴了系統(tǒng),當(dāng)使用該工具時,由系統(tǒng)幫我們?nèi)フ抑付ǖ哪夸?。n特點:系統(tǒng)默認先去當(dāng)前路徑下找要執(zhí)行的程序,如果沒有,再去path中設(shè)置的路徑下找。如果指定了classpath,那么會在指定的目錄下查找要運行的一般不指定分號,如果沒有在指定目錄下找到要運行的類文件,就報錯,這樣可以調(diào)試程序。的編譯器程序。對指定擴展名的.java文件進行編譯。生成了一個文件要被執(zhí)行,必須要有一個執(zhí)行的起始點,這個起始點就----------------------------------------------------------------------------------------------保留字:其實就是還沒有賦予特殊含義,但是準(zhǔn)備日后要使用rnameyour_name_yournameHelloCareers1),數(shù)字不可以開頭。2),不可以使用關(guān)鍵字。4,變量:其實就是內(nèi)存中的一個存儲空間,用于存儲常量數(shù)作用:方便于運算。因為有些數(shù)據(jù)不確定。所以確定該數(shù)據(jù)的特點:變量空間可以重復(fù)使用。1,這個空間要存儲什么數(shù)據(jù)?數(shù)據(jù)類型。2,這個空間叫什么名字???變量名稱。變量的作用域和生存期:作用域從變量定義的位置開始,到該變量所在的那對大括號結(jié)束;變量從定義的位置開始就在內(nèi)存中活了;變量到達它所在的作用域的時候就在內(nèi)存中消失了;數(shù)據(jù)類型:1):基本數(shù)據(jù)類型:byte、short、int、long、float、double、char、boolean2):引用數(shù)據(jù)類型:數(shù)組、類、接口。級別從低到高為:byte,char,short(這三個平級)-->int-->float-->long-->double1)、算術(shù)運算符。算。++,--2)、賦值運算符。=+=-=*=/=%=3)、比較運算符。符的特點是:運算完的結(jié)果,要么是true,要么是false。4)、邏輯運算符。&|^!&&||true.&&:短路與,如果左邊為false,那么右邊不參數(shù)與運算。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=aa=a^b;//a=a^b^a=b;練習(xí):高效的算出2*8=2<<3;Ifswitchdowhilewhilefor1)、當(dāng)判斷固定個數(shù)的值的時候,可以使用if,也可以使用switch。建議使用switch,效率相對較高。switch(變量){case值:要執(zhí)行的語句;break;…default:要執(zhí)行的語句;}2):switch后面的小括號中的變量應(yīng)該是byte,char,short,int四種類型中的一種;3):default可以寫在switch結(jié)構(gòu)中的任意位置;如果將default語句放在了第一行,則不管k2)、當(dāng)判斷數(shù)據(jù)范圍,獲取判斷運算結(jié)果boolean類型時,需要使用if。3)、當(dāng)某些語句需要執(zhí)行很多次時,就用循環(huán)結(jié)構(gòu)。forfor中釋放。break:作用于switch,和循環(huán)語句,用于跳出,或者稱為結(jié)束。前所在循環(huán)。要跳出嵌套中的外部循環(huán),只要給循環(huán)起名字即可,這個名字稱之為標(biāo)號。continue:只作用于循環(huán)結(jié)構(gòu),繼續(xù)循環(huán)用的。作用:結(jié)束本次循環(huán),繼續(xù)下次循環(huán)。該語句單獨存在時,下面不可以定義語句,執(zhí)行不到。修飾符返回值類型函數(shù)名(參數(shù)類型形式參數(shù)1,參數(shù)類型形式參數(shù)1,…){}函數(shù)其實就是一個功能,定義函數(shù)就是實現(xiàn)功能,通過兩個明確來完成:1)、明確該功能的運算完的結(jié)果,其實是在明確這個函數(shù)的返回值類型。2)、在實現(xiàn)該功能的過程中是否有未知內(nèi)容參與了運算,其實就是在明確這個函數(shù)的參數(shù)列表(參數(shù)類型&參數(shù)個數(shù))。1)、用于定義功能。2)、用于封裝代碼提高代碼的復(fù)用性。注意:函數(shù)中只能調(diào)用函數(shù),不能定義函數(shù)。獨立運行。2)、因為它是程序的入口。函數(shù)定義名稱是為什么呢?答:1)、為了對該功能進行標(biāo)示,方便于調(diào)用。2)、為了通過名稱就可以明確函數(shù)的功能,為了增加代碼的閱讀性。重載的定義是:在一個類中,如果出現(xiàn)了兩個或者兩個以上的同名函數(shù),只要它們的參數(shù)的個數(shù),或者參數(shù)的類型不同,即可稱之為該函數(shù)重載了。于封裝數(shù)據(jù),就是一個具體的實體。1)、元素類型[]變量名=new元素類型[元素的個數(shù)];;的下標(biāo)0所對應(yīng)的位置開始存取。它導(dǎo)入---------------------------------------------------------//二分查找法。必須有前提:數(shù)組中的元素要有序。publicclassBubbleTest{publicstaticintbinary(int[]array,intvalue){intlow=0;inthigh=array.length-1;while(low<=high){intmiddle=(low+high)/2;if(value==array[middle]){returnmiddle;}if(value>array[middle]){low=middle+1;}if(value<array[middle]){high=middle-1;}}return-1;}publicstaticvoidmain(String[]args){int[]a={1,2,3,4,5,6,7,8,9};intvalue=binary(a,9);System.out.println(value);}}heapsegmentnewjvm沒有引用指向這個對象就回收3、靜態(tài)區(qū)(datasegment)—存放,和,不釋放4、代碼區(qū)(codesegment)—存放程序中方法的,而且是多個對象共享一個代碼----------------------------------------------------------------------------------------------三:面向?qū)ο螅骸铩铩铩铩?:面向?qū)ο髮⒁郧暗倪^程中的執(zhí)行者,變成了指揮者。3:面向?qū)ο筮@種思想是符合現(xiàn)在人們思考習(xí)慣的一種思想。匿名對象使用場景:1:當(dāng)對方法只進行一次調(diào)用的時候,可以使用匿名對象。2:當(dāng)對象對成員進行多次調(diào)用時,不能使用匿名對象。必須給對象起名字。在類中定義其實都稱之為成員。成員有兩種:1:成員變量:其實對應(yīng)的就是事物的屬性。2:成員函數(shù):其實對應(yīng)的就是事物的行為。所以,其實定義類,就是在定義成員變量和成員函數(shù)。但是在定義前,必須先要對事物進行屬性和行為的分析,才可以用代碼來體現(xiàn)。privateintage;//私有的訪問權(quán)限最低,只有在本類中的訪問有效。注意:私有僅僅是封裝的一種體現(xiàn)形式而已。私有的成員:其他類不能直接創(chuàng)建對象訪問,所以只有通過本類對外提供具體的訪問方式來完成對私有的訪問,可以通過對外提供函數(shù)的形式對其進行訪問。好處:可以在函數(shù)中加入邏輯判斷等操作,對數(shù)據(jù)進行判斷等操作??偨Y(jié):開發(fā)時,記住,屬性是用于存儲數(shù)據(jù)的,直接被訪問,容易出現(xiàn)安全隱患,所以,類中的屬性通常被私這個方法一般有兩個,規(guī)范寫法:對于屬性xxx,可以使用setXXX(),getXXX()對其進行操作。jvm。成員變量和局部變量的區(qū)別:1:成員變量直接定義在類中。2:成員變量在這個類中有效。局部變量只在自己所屬的大括號內(nèi)有效,大括號結(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ù)列表來區(qū)分。所以,一個類中如果出現(xiàn)多個構(gòu)造函數(shù)。它們的存在是以重載體現(xiàn)的。是在對象創(chuàng)建時,就被調(diào)用,用于初始化,而且初始化動作只執(zhí)行一次。一般函數(shù),是對象創(chuàng)建后,需要調(diào)用才執(zhí)行,可以被調(diào)用多次。分析事物時,發(fā)現(xiàn)具體事物一出現(xiàn),就具備了一些特征,那就將這些特征定義到構(gòu)造函數(shù)內(nèi)。構(gòu)造代碼塊:是給所有的對象進行初始化,也就是說,所有的對象都會調(diào)用一個代碼塊。只要對象一建立。就會調(diào)用這個代碼塊。構(gòu)造函數(shù):是給與之對應(yīng)的對象進行初始化。它具有針對性。Personp=newPerson();創(chuàng)建一個對象都在內(nèi)存中做了什么事情?1:先將硬盤上指定位置的Person.class文件加載進內(nèi)存。個變量p。內(nèi)存首地址值。new4:在該實體空間中進行屬性的空間分配,并進行了默認初始化。5:對空間中的屬性進行顯示初始化。6:進行實體的構(gòu)造代碼塊初始化。pp。(指向了該對象)--------------------------------------------------------------------------------------------封裝(面向?qū)ο筇卣髦?:是指隱藏對象的屬性和實現(xiàn)細節(jié),僅對外提供公共訪問方式。。封裝原則:將不需要對外提供的內(nèi)容都隱藏起來,把屬性都隱藏,提供公共方法對其訪問。this:代表對象。就是所在函數(shù)所屬對象的引用。在定義功能時,如果該功能內(nèi)部使用到了調(diào)用該功能的對象,這時就用this來表示這個對象。this還可以用于構(gòu)造函數(shù)間的調(diào)用。this對象后面跟上.調(diào)用的是成員屬性和成員方法(一般方法);this對象后面跟上()調(diào)用的是本類中的對應(yīng)參數(shù)的構(gòu)造函數(shù)。注意:用this調(diào)用構(gòu)造函數(shù),必須定義在構(gòu)造函數(shù)的第一行。因為構(gòu)造函數(shù)是用于初始化的,所以初始化動作關(guān)鍵字,是一個修飾符,用于修飾成員(成員變量和成員函數(shù))。1,想要實現(xiàn)對象中的共性數(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)修飾的。因為那樣的話,特有數(shù)據(jù)會變成對象的共享數(shù)據(jù)。這樣對事物的描述就出了問題。所以,在定義靜態(tài)時,必須要明確,這個數(shù)據(jù)是否是被對象所共享的。2,靜態(tài)方法只能訪問靜態(tài)成員,不可以訪問非靜態(tài)成員。因為靜態(tài)方法加載時,優(yōu)先于對象存在,所以沒有辦法訪問對象中的成員。態(tài)的。該成員變量的數(shù)據(jù)是否是所有對象都一樣:如果是,那么該變量需要被靜態(tài)修飾,因為是共享的數(shù)據(jù)。如果不是,那么就說這是對象的特有數(shù)據(jù),要存儲到對象中。法中沒有調(diào)用特有數(shù)據(jù)時就定義成靜態(tài))成員函數(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)代碼塊隨著類的加載而執(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[0]。jvm默認傳遞的是長度為0的字符串?dāng)?shù)組,我們在運行該類時,也可以指定具體的參數(shù)進行傳遞??梢栽诳刂苆vm參數(shù)作為args數(shù)組中的元素,進行存儲。靜態(tài)代碼塊、構(gòu)造代碼塊、構(gòu)造函數(shù)同時存在時的執(zhí)行順序:靜態(tài)代碼塊>構(gòu)造代碼塊>構(gòu)造函數(shù);生成Java幫助文檔:命令格式:javadoc–d文件夾名–auther–version*.java/**//格式*類描述*@author作者名*@version版本號*方法描述*@param參數(shù)描述*@return返回值描述---------------------------------------------------------------------------------------------設(shè)計模式:解決問題最行之有效的思想。是一套被反復(fù)使用、多數(shù)人知曉的、經(jīng)過分類編目的、代碼設(shè)計經(jīng)驗的總結(jié)。使用設(shè)計模式是為了可重用代碼、讓代碼更容易被他人理解、保證代碼可靠性。單例設(shè)計模式:★★★★★解決的問題:保證一個類在內(nèi)存中的對象唯一性。比如:多程序讀取一個配置文件時,建議配置文件封裝成對象。會方便操作其中數(shù)據(jù),又要保證多個程序讀到的是同一個配置文件對象,就需要該配置文件對象在內(nèi)存中是唯一的。Runtime()方法就是單例設(shè)計模式進行設(shè)計的。不讓其他程序創(chuàng)建該類對象。2,在本類中創(chuàng)建一個本類對象。1,因為創(chuàng)建對象都需要構(gòu)造函數(shù)初始化,只要將本類中的構(gòu)造函數(shù)私有化,其他程序就無法再創(chuàng)建該類對2,就在類中創(chuàng)建一個本類的對象;3,定義一個方法,返回該對象,讓其他程序可以通過方法就得到本類對象。(作用:可控),創(chuàng)建私有并靜態(tài)的本類對象;3,定義公有并靜態(tài)的方法,返回該對象。---------------------------------------------//餓漢式classSingle{privateSingle(){}//私有化構(gòu)造函數(shù)。privatestaticSingles=newSingle();//創(chuàng)建私有并靜態(tài)的本類對象。publicstaticSinglegetInstance(){//定義公有并靜態(tài)的方法,返回該對象。returns;}}---------------------------------------------//懶漢式:延遲加載方式。classSingle2{privateSingle2(){}privatestaticSingle2s=null;publicstaticSingle2getInstance(){snulls=newSingle2();returns;}}-------------------------------------------------------------------------------------------------復(fù)用性。2:讓類與類之間產(chǎn)生了關(guān)系,提供了另一個特征多態(tài)的前提。父類的由來:其實是由多個類不斷向上抽取共性內(nèi)容而來的。單繼承:一個類只能有一個父類。多繼承:一個類可以有多個父類。因為當(dāng)一個類同時繼承兩個父類時,兩個父類中有相同的功能,那么子類對象調(diào)用該功能時,運行哪一個多重繼承的出現(xiàn),就有了繼承體系。體系中的頂層父類是通過不斷向上抽取而來的。它里面定義的該體系基本最共性內(nèi)容的功能。所以,一個體系要想被使用,直接查閱該系統(tǒng)中的父類的功能即可知道該體系的基本用法。那么想要使用一個體系時,需要建立對象。建議建立最子類對象,因為最子類不僅可以使用父類中的功能。還可以使用子類簡單說:對于一個繼承體系的使用,查閱頂層父類中的內(nèi)容,創(chuàng)建最底層子類的對象。子父類出現(xiàn)后,類中的成員都有了哪些特點:當(dāng)子父類中出現(xiàn)一樣的屬性時,子類類型的對象,調(diào)用該屬性,值是子類的屬性值。This:代表是本類類型的對象引用。Super:代表是子類所屬的父類中的內(nèi)存空間引用。注意:子父類中通常是不會出現(xiàn)同名成員變量的,因為父類中只要定義了,子類就不用在定義了,直接繼當(dāng)子父類中出現(xiàn)了一模一樣的方法時,建立子類對象會運行子類中的方法。好像父類中的方法被覆蓋掉一另一個特性:覆蓋(復(fù)寫,重寫)什么時候使用覆蓋呢?當(dāng)一個類的功能內(nèi)容需要修改時,可以通過覆蓋來實現(xiàn)。造函數(shù)。為什么呢?super():表示父類的構(gòu)造函數(shù),并會調(diào)用于參數(shù)相對應(yīng)的父類中的構(gòu)造函數(shù)。而super():是在調(diào)用父類為什么子類對象初始化時,都需要調(diào)用父類中的函數(shù)?(為什么要在子類構(gòu)造函數(shù)的第一行加入這個super)?)因為子類繼承父類,會繼承到父類中的數(shù)據(jù),所以必須要看父類是如何對自己的數(shù)據(jù)進行初始化的。所以注意:子類中所有的構(gòu)造函數(shù)都會默認訪問父類中的空參數(shù)的構(gòu)造函數(shù),因為每一個子類構(gòu)造內(nèi)第一行都super);如果父類中沒有空參數(shù)的構(gòu)造函數(shù),那么子類的構(gòu)造函數(shù)內(nèi),必須通過super語句指定要訪問的父類中的如果子類構(gòu)造函數(shù)中用this來指定調(diào)用子類自己的構(gòu)造函數(shù),那么被調(diào)用的構(gòu)造函數(shù)也一樣會訪問父類中問題:super()和this()是否可以同時出現(xiàn)的構(gòu)造函數(shù)中。兩個語句只能有一個定義在第一行,所以只能出現(xiàn)其中一個。s繼承的細節(jié):ab中的一種。a繼承b。狼是犬科中的一種。注意:不要僅僅為了獲取其他類中的已有成員進行繼承。所以判斷所屬關(guān)系,可以簡單看,如果繼承后,被繼承的類中的功能,都可以被該子類所具備,那么繼承成立。如果不是,不可以繼承。1:子類覆蓋父類時,必須要保證,子類方法的權(quán)限必須大于等于父類方法權(quán)限可以實現(xiàn)繼承。否則,編譯2:覆蓋時,要么都靜態(tài),要么都不靜態(tài)。(靜態(tài)只能覆蓋靜態(tài),或者被靜態(tài)覆蓋)繼承的一個弊端:打破了封裝性。對于一些類,或者類中功能,是需要被繼承,或者復(fù)寫的。1:這個關(guān)鍵字是一個修飾符,可以修飾類,方法,變量。其實這樣的原因的就是給一些固定的數(shù)據(jù)起個閱讀性較強的名稱。al常量名稱定義時,有規(guī)范,所有字母都大寫,如果由多個單詞組成,中間用_連接。抽象:不具體,看不明白。抽象類表象體現(xiàn)。t只能定義在抽象類中,抽象類和抽象方法必須由abstract關(guān)鍵字修飾(可以描述類和方法,不可以描述變量)。2:抽象方法只定義方法聲明,并不定義方法實現(xiàn)。3:抽象類不可以被創(chuàng)建對象(實例化)。4:只有通過子類繼承抽象類并覆蓋了抽象類中的所有抽象方法后,該子類才可以實例化。否則,該子類還是一個抽象類。細節(jié):于給子類對象進行初始化??梢?。其實,抽象類和一般類沒有太大的區(qū)別,都是在描述事物,只不過抽象類在描述事物時,有些功能不具體。所以抽象類和一般類在定義上,都是需要定義屬性和行為的。只不過,比一般類多了一個抽象函數(shù)。而且比一般類少了一個創(chuàng)建對象的部分。3:抽象關(guān)鍵字abstract和哪些不可以共存?final,private,static4:抽象類中可不可以不定義抽象方法?可以。抽象方法目的僅僅為了不讓該類創(chuàng)建對象。-----------------------------------------------------------------------------------------------解決的問題:當(dāng)功能內(nèi)部一部分實現(xiàn)時確定,一部分實現(xiàn)是不確定的。這時可以把不確定的部分暴露出去,讓abstractclassGetTime{publicfinalvoidgetTime(){//此功能如果不需要復(fù)寫,可加final限定longstart=System.currentTimeMillis();code();//不確定的功能部分,提取出來,通過抽象方法實現(xiàn)longend=System.currentTimeMillis();}publicabstractvoidcode();//抽象不確定的功能,讓子類復(fù)寫實現(xiàn)}classSubDemoextendsGetTime{defor(inty=0;y<1000;y++){System.out.println("y");}}}---------------------------------------------------------------------------------------------接口:★★★★★2:接口中包含的成員,最常見的有全局常量、抽象方法。注意:接口中的成員都有固定的修飾符。linterfaceInter{publicstaticfinalintx=3;publicabstractvoidshow();3:接口中有抽象方法,說明接口不可以實例化。接口的子類必須實現(xiàn)了接口中所有的抽象方法后,該子類才可以實例化。否則,該子類還是一個抽象類。4:類與類之間存在著繼承關(guān)系,類與接口中間存在的是實現(xiàn)關(guān)系。5:接口和類不一樣的地方,就是,接口可以被多實現(xiàn),這就是多繼承改良后的結(jié)果。java將多繼承機制通過6:一個類在繼承另一個類的同時,還可以實現(xiàn)多個接口。所以接口的出現(xiàn)避免了單繼承的局限性。還可以將類進行功能的擴展。接口都用于設(shè)計上,設(shè)計上的特點:(可以理解主板上提供的接口)1:接口是對外提供的規(guī)則。2:接口是功能的擴展。3:接口的出現(xiàn)降低了耦合性。抽象類:一般用于描述一個體系單元,將一組共性內(nèi)容進行抽取,特點:可以在類中定義抽象內(nèi)容讓子類實現(xiàn),可以定義非抽象內(nèi)容讓子類直接使用。它里面定義的都是一些體系中的基本內(nèi)容。展功能,是在繼承之外還需這個對象具備的一些功能。1:抽象類只能被繼承,而且只能單繼承。接口需要被實現(xiàn),而且可以多實現(xiàn)。2:抽象類中可以定義非抽象方法,子類可以直接繼承使用。接口中都有抽象方法,需要子類去實現(xiàn)。3:抽象類使用的是isa關(guān)系。接口使用的likea關(guān)系。4:抽象類的成員修飾符可以自定義。------------------------------------------------------------------------------------------------多態(tài)★★★★★(面向?qū)ο筇卣髦?:函數(shù)本身就具備多態(tài)性,某一種事物有不同的具體的體現(xiàn)。多態(tài)的好處:提高了程序的擴展性。多態(tài)的弊端:當(dāng)父類引用指向子類對象時,雖然提高了擴展性,但是只能訪問父類中具備的方法,不可以訪問態(tài)的前提:2:通常會有覆蓋操作。多態(tài)的出現(xiàn)思想上也做著變化:以前是創(chuàng)建對象并指揮對象做事情。有了多態(tài)以后,我們可以找到對象的共性類型,直接操作共性類型做事情即可,這樣可以指揮一批對象做事情,即通過操作父類或接口實現(xiàn)。--------------------------------------------------------------class畢姥爺{void講課(){System.out.println("企業(yè)管理");}void釣魚(){System.out.println("釣魚");}}class畢老師extends畢姥爺{void講課(){System.out.println("JAVA");}void看電影(){System.out.println("看電影");}}class{publicstaticvoidmain(String[]args){畢姥爺x=new畢老師();//畢老師對象被提升為了畢姥爺類型。//x.講課();//x.看電影();//錯誤.畢老師y=(畢老師)x;//將畢姥爺類型強制轉(zhuǎn)換成畢老師類型。y.看電影();//在多態(tài)中,自始自終都是子類對象在做著類型的變化。}}---------------------------------------------------------------如果想用子類對象的特有方法,如何判斷對象是哪個具體的子類類型呢?可以可以通過一個關(guān)鍵字instanceof;//判斷對象是否實現(xiàn)了指定的接口或繼承了指定的類instanceof類型。多態(tài)在子父類中的成員上的體現(xiàn)的特點:在編譯時期:參考的是引用型變量所屬的類中是否有調(diào)用的成員。(編譯時不產(chǎn)生對象,只檢查語法錯誤)運行時期:也是參考引用型變量所屬的類中是否有調(diào)用的成員。簡單一句話:無論編譯和運行,成員變量參考的都是引用變量所屬的類中的成員變量。:成員變量---編譯運行都看=左邊。2,成員函數(shù)。編譯時期:參考引用型變量所屬的類中是否有調(diào)用的方法。運行事情:參考的是對象所屬的類中是否有調(diào)用的方法。為什么是這樣的呢?因為在子父類中,對于一模一樣的成員函數(shù),有一個特性:覆蓋。簡單一句:成員函數(shù),編譯看引用型變量所屬的類,運行看對象所屬的類。更簡單:成員函數(shù)---編譯看=左邊,運行看=右邊。3,靜態(tài)函數(shù)。編譯時期:參考的是引用型變量所屬的類中是否有調(diào)用的成員。運行時期:也是參考引用型變量所屬的類中是否有調(diào)用的成員。調(diào)用靜態(tài)的方法引用是哪個類的引用調(diào)用的就是哪個類中的靜態(tài)方法。-----------------------------------------------------------------------------------------------------java.lang.Object的向上抽取,最終就抽取到了一個最頂層的類中的,該類中定義的就是所有對象都具備的功能。1,booleanequals(Objectobj):用于比較兩個對象是否相等,其實內(nèi)部比較的就是兩個對象地址。而根據(jù)對象的屬性不同,判斷對象是否相同的具體內(nèi)容也不一樣。所以在定義類時,一般都會復(fù)寫equals方法,建立本類特有的判斷對象是否相同的依據(jù)。publicbooleanequals(Objectobj){if(!(objinstanceofPerson))returnfalse;Personp=(Person)obj;returnthis.age==p.age;}2,StringtoString():將對象變成字符串;默認返回的格式:類名@哈希值=getClass().getName()+'@'+Integer.toHexString(hashCode())為了對象對應(yīng)的字符串內(nèi)容有意義,可以通過復(fù)寫,建立該類對象自己特有的字符串表現(xiàn)形式。publicStringtoString(){return"person:"+age;}3,ClassgetClass():獲取任意對象運行時的所屬字節(jié)碼文件對象。4,inthashCode():返回該對象的哈希碼值。支持此方法是為了提高哈希表的性能。通常equals,toString,hashCode,在應(yīng)用中都會被復(fù)寫,建立具體對象的特有的內(nèi)容。------------------------------------------------------------------------------------------------訪問內(nèi)部類,必須要建立內(nèi)部類的對象。-----------------------------------------------------classOuter{intnum=4;classInner{voidshow(){System.out.println("innershowrun"+num);}}publicvoidmethod(){Innerin=newInner();//創(chuàng)建內(nèi)部類的對象。}}-------------------------------------------------------當(dāng)內(nèi)部類定義在外部類中的成員位置上,可以使用一些成員修飾符修飾private、static。直接訪問內(nèi)部類格式:外部類名.內(nèi)部類名變量名=外部類對象.內(nèi)部類對象;Outer.Innerin=newOuter.newInner();//這種形式很少用。但是這種應(yīng)用不多見,因為內(nèi)部類之所以定義在內(nèi)部就是為了封裝。想要獲取內(nèi)部類對象通常都通過外部類的方法來獲取。這樣可以對內(nèi)部類對象進行控制。通常內(nèi)部類被封裝,都會被私有化,因為封裝性不讓其他程序直接訪問。如果內(nèi)部類被靜態(tài)修飾,相當(dāng)于外部類,會出現(xiàn)訪問局限性,只能訪問外部類中的靜態(tài)成員。的。內(nèi)部類編譯后的文件名為:“外部類名$內(nèi)部類名.java”;那是因為內(nèi)部中都持有一個外部類的引用。這個是引用是外部類名.this內(nèi)部類可以定義在外部類中的成員位置上,也可以定義在外部類中的局部位置上。final局部變量。匿名內(nèi)部類:沒有名字的內(nèi)部類。就是內(nèi)部類的簡化形式。一般只用一次就可以用這種形式。匿名內(nèi)部類其實就是一個匿名子類對象。想要定義匿名內(nèi)部類:需要前提,內(nèi)部類必須繼承一個類或者實現(xiàn)接口。式:new父類名&接口名(){定義子類成員或者覆蓋父類方法}.方法。當(dāng)函數(shù)的參數(shù)是接口類型引用時,如果接口中的方法不超過3個??梢酝ㄟ^匿名內(nèi)部類來完成參數(shù)的傳其實就是在創(chuàng)建匿名內(nèi)部類時,該類中的封裝的方法不要過多,最好兩個或者兩個以內(nèi)。--------------------------------------------------------//面試1newObject(){voidshow(){System.out.println("showrun");}/2Objectobj=newObject(){voidshow(){System.out.println("showrun");}tbj-------------------------------------------------------classInnerClassDemo6{+(static)classInner{voidshow(){}}publicvoidmethod(){this.newInner().show();//可以}publicstaticvoidmainStringargs/static不允許this}}------------------------------------------------------interfaceInter{voidshow();}publicstaticIntermethod(){returnnewInter(){publicvoidshow(){}}}classInnerClassDemo7{publicstaticvoidmain(String[]args){Outer.method().show();howfunction(newInter(){publicvoidshow(){}});//匿名內(nèi)部類作為方法的參數(shù)進行傳遞。}publicstaticvoidfunction(Interin){}}------------------------------------------------------------------------------------------------異常:★★★★異常:就是不正常。程序在運行時出現(xiàn)的不正常情況。其實就是程序中出現(xiàn)的問題。這個問題按照面向?qū)ο笏枷脒M行描述,并封裝成了對象。因為問題的產(chǎn)生有產(chǎn)生的原因、有問題的名稱、有問題的描述等多個屬性信息存在。當(dāng)出現(xiàn)多屬性信息最方便的方式就是將這些信息進行封裝。異常就是java按照面向?qū)ο蟮乃枷雽栴}進行對象封裝。這樣就方便于操作問題以及處理問題。出現(xiàn)的問題有很多種,比如角標(biāo)越界,空指針等都是。就對這些問題進行分類。而且這些問題都有共性內(nèi)容比如:每一個問題都有名稱,同時還有問題描述的信息,問題出現(xiàn)的位置,所以可以不斷的向上抽取。形成了異常體系。--------java.lang.Throwable:Throwable。|--Error:錯誤,一般情況下,不編寫針對性的代碼進行處理,通常是jvm發(fā)生的,需要對程序進行修|--Exception:異常,可以有針對性的處理方式無論是錯誤還是異常,它們都有具體的子類體現(xiàn)每一個問題,它們的子類都有一個共性,就是都以父類名才作為子類的后綴名。這個體系中的所有類和對象都具備一個獨有的特點;就是可拋性。------------------------------------------------------classExceptionDemo{publicstaticvoidmain(String[]args){//byte[]buf=newbyte[1024*1024*700];//java.lang.OutOfMemoryError內(nèi)存溢出錯誤}}------------------------------------------------------在開發(fā)時,如果定義功能時,發(fā)現(xiàn)該功能會出現(xiàn)一些問題,應(yīng)該將問題在定義功能時標(biāo)示出來,這樣調(diào)用者就可以在使用這個功能的時候,預(yù)先給出處理方式。這樣標(biāo)示后,調(diào)用者,在使用該功能時,就必須要處理,否則編譯失敗。try{}catch(異常類變量名){}fianlly{}--------------------------------------------------------System.out.println("message:"+e.getMessage());//獲取的是異常的信息。System.out.println("toString:"+e.toString());//獲取的是異常的名字+異常的信息。e.printStackTrace();//打印異常在堆棧中信息;異常名稱+異常信息+異常的位置。}---------------------------------------------------------處理有針對性,拋幾個就處理幾個。通常情況:函數(shù)內(nèi)容如果有throw,拋出異常對象,并沒有進行處理,那么函數(shù)上一定要聲明,否則編譯失敗。但是也有特殊情況。ntimeException行異常,也就說這個異常是編譯時不被檢查的異常。編譯時被檢查的異常和運行時異常的區(qū)別:編譯被檢查的異常在函數(shù)內(nèi)被拋出,函數(shù)必須要聲明,否編譯失敗。聲明的原因:是需要調(diào)用者對該異常進行處理。運行時異常如果在函數(shù)內(nèi)被拋出,在函數(shù)上不需要聲明。不聲明的原因:不需要調(diào)用者處理,運行時異常發(fā)生,已經(jīng)無法再讓程序繼續(xù)運行,所以,不讓調(diào)用處理的,直接讓程序停止,由調(diào)用者對代碼進行修正。功能內(nèi)部如果出現(xiàn)異常,如果內(nèi)部可以處理,就用try;如果功能內(nèi)部處理不了,就必須聲明出來,讓調(diào)用者處理。對于除法運算,0作為除數(shù)是不可以的。java中對這種問題用ArithmeticException類進行描述。對于這個我們就需要自定義這個異常。異常的轉(zhuǎn)換思想:當(dāng)出現(xiàn)的異常是調(diào)用者處理不了的,就需要將此異常轉(zhuǎn)換為一個調(diào)用者可以處理的異常拋trycatchfinallyfinally的幾種結(jié)合方式:hfinally這種情況,如果出現(xiàn)異常,并不處理,但是資源一定關(guān)閉,所以tryfinally集合只為關(guān)閉資源。當(dāng)異常出現(xiàn)后,在子父類進行覆蓋時,有了一些新的特點:1:當(dāng)子類覆蓋父類的方法時,如果父類的方法拋出了異常,那么子類的方法要么不拋出異常要么拋出父類異?;蛘咴摦惓5淖宇悾荒軖伋銎渌惓?。2:如果父類拋出了多個異常,那么子類在覆蓋時只能拋出父類的異常的子集。如果父類或者接口中的方法沒有拋出過異常,那么子類是不可以拋出異常的,如果子類的覆蓋的方法中出如果這個異常子類無法處理,已經(jīng)影響了子類方法的具體運算,這時可以在子類方法中,通過throw拋出Exceptionthrows1、腳標(biāo)越界異常(IndexOutOfBoundsException)包括數(shù)組、字符串;空指針異常(NullPointerException)異常要盡量避免,如果避免不了,需要預(yù)先給出處理方式。比如家庭備藥,比如滅火器。-----------------------------------------------------------------------------------------------2:給類文件提供多層名稱空間。如果生成的包不在當(dāng)前目錄下,需要最好執(zhí)行classpath,將包所在父目錄定義到classpath變量中即可。使用url域名來進行包名稱的定義。packagepack;//定義了一個包,名稱為pack。注意:包名的寫法規(guī)范:所有字母都小寫。//packagecn.itcast.pack.demo;類的全名稱是包名.類名包是一種封裝形式,用于封裝類,想要被包以外的程序訪問,該類必須public;類中的成員,如果被包以外訪問,也必須public;包與包之間訪問可以使用的權(quán)限有兩種:2:protected:只能是不同包中的子類可以使用的權(quán)限。類不同包中publicprotecteddefaultprivate-----------------------------------------------------------------------------------------------Import-導(dǎo)入:類名稱變長,寫起來很麻煩。為了簡化,使用了一個關(guān)鍵字:import,可以使用這個關(guān)鍵字導(dǎo)入指定包中的類。記?。簩嶋H開發(fā)時,到的哪個類就導(dǎo)入哪個類,不建議使用*.importpacka.*;//這個僅僅是導(dǎo)入了packa當(dāng)前目錄下的所有的類。不包含子包。如果導(dǎo)入的兩個包中存在著相同名稱的類。這時如果用到該類,必須在代碼中指定包名。temStringThrowablejdkjavax.swing:提供所有的windows桌面應(yīng)用程序包括的控件,比如:Frame,Dialog,Table,List等等,就java.io:inputoutput用于操作設(shè)備上數(shù)據(jù)的對象都在該包中。比如:讀取硬盤數(shù)據(jù),往硬盤寫入數(shù)據(jù)。java.util:java的工具包,時間對象,集合框架。jar:java的壓縮包,主要用于存儲類文件,或者配置文件等。命令格式:jar–cf包名.jar包目錄-----------------------------------------------------------------------------------------------的程序。其實進程就是一個應(yīng)用程序運行時的內(nèi)存分配空間。線程:其實就是進程中一個程序執(zhí)行控制單元,一條執(zhí)行路徑。進程負責(zé)的是應(yīng)用程序的空間的標(biāo)示。線程負責(zé)的是應(yīng)用程序的執(zhí)行順序。一個進程至少有一個線程在運行,當(dāng)一個進程中出現(xiàn)多個線程時,就稱這個應(yīng)用程序是多線程應(yīng)用程序,每個區(qū)、自己的變量。當(dāng)產(chǎn)生垃圾時,收垃圾的動作,是不需要主線程來完成,因為這樣,會出現(xiàn)主線程中的代碼執(zhí)行會停止,會去回收器代碼,效率較低,所以由單獨一個線程來負責(zé)垃圾回收。返回當(dāng)前線程的名稱:Thread.currentThread().getName()線程要運行的代碼都統(tǒng)一存放在了run方法中。start方法:1)、啟動了線程;2)、讓jvm調(diào)用了run方法。tnotify創(chuàng)建線程的第二種方式:實現(xiàn)一個接口Runnable。2,覆蓋接口中的run方法(用于封裝線程要運行的代碼)。nTickett=newTicket();Thread類的子類,就只能用Thread類。Threadt1=newThread(t);//創(chuàng)建線程。t1.start();1:通過繼承Thread類的方式,可以完成多線程的建立。但是這種方式有一個局限性,如果一個類已經(jīng)有了自被多個線程同時執(zhí)行。這時怎么辦呢?只有對該類進行額外的功能擴展,java就提供了一個接口Runnable。這個接口中定義了run方法,其實run運行的代碼。所以,通常創(chuàng)建線程都用第二種方式。2:其實是將不同類中需要被多線程執(zhí)行的代碼進行抽取。將多線程要運行的代碼的位置單獨定義到接口中。為其他類進行功能擴展提供了前提。類復(fù)寫的。但是不需要做這個復(fù)寫動作的話,只為定義線程代碼存放位置,實現(xiàn)Runnable接口更方便一些。所Runnable-------------------------------------------------------//面試newThread(newRunnable(){//匿名publicvoidrun(){System.out.println("runnablerun");}{publicvoidrun(){System.out.println("subthreadrun");}---------------------------------------------------------Try{Thread.sleep(10);}catch(InterruptedExceptione){}//當(dāng)刻意讓線程稍微停一下,模擬cpu切換情況。多線程安全問題的原因:通過圖解:發(fā)現(xiàn)一個線程在執(zhí)行多條語句時,并運算同一個數(shù)據(jù)時,在執(zhí)行過程中,其他線程參與進來,并操作了這個數(shù)據(jù)。導(dǎo)致到了錯誤數(shù)據(jù)的產(chǎn)生。涉及到兩個因素:1,多個線程在操作共享數(shù)據(jù)。2,有多條語句對共享數(shù)據(jù)進行運算。原因:這多條語句,在某一個時刻被一個線程執(zhí)行時,還沒有執(zhí)行完,就被其他線程執(zhí)行了。解決安全問題的原理:只要將操作共享數(shù)據(jù)的語句在某一時段讓一個線程執(zhí)行完,在執(zhí)行過程中,其他線程不能進來執(zhí)行就可以解synchronized(對象){//任意對象都可以。這個對象就是鎖。}---------------------------------------------------------------弊端:相對降低性能,因為判斷鎖需要消耗資源,產(chǎn)生了死鎖。定義同步是有前提的:1,必須要有兩個或者兩個以上的線程,才需要同步。2,多個線程必須保證使用的是同一個鎖。同步函數(shù):其實就是將同步關(guān)鍵字定義在函數(shù)上,讓函數(shù)具備了同步性。his靜態(tài)函數(shù)在加載時所屬于類,這時有可能還沒有該類產(chǎn)生的對象,但是該類的字節(jié)碼文件加載進內(nèi)存就已經(jīng)被封裝成了對象,這個對象就是該類的字節(jié)碼文件對象。這個對象就是類名.class同步代碼塊和同步函數(shù)的區(qū)別?步代碼塊使用的鎖可以是任意對象。同步函數(shù)使用的鎖是this,靜態(tài)同步函數(shù)的鎖是該類的字節(jié)碼文件對象。在一個類中只有一個同步,可以使用同步函數(shù)。如果有多同步,必須使用同步代碼塊,來確定不同的鎖。所以同步代碼塊相對靈活一些。-------------------------------------------------------當(dāng)多線程訪問懶漢式時,因為懶漢式的方法內(nèi)對共性數(shù)據(jù)進行多條語句的操作。所以容易出現(xiàn)線程安全問為了效率問題,通過雙重判斷的形式解決。classSingle{privatestaticSingles=null;privateSingle(){}publicstaticSinglegetInstance(){//鎖是誰?字節(jié)碼文件對象;if(s==null){synchronized(Single.class){if(s==null)s=newSingle();}}returns;}}---------------------------------------------------------同步死鎖:通常只要將同步進行嵌套,就可以看到現(xiàn)象。同步函數(shù)中有同步代碼塊,同步代碼塊中還有同步函線程間通信:思路:多個線程在操作同一個資源,但是操作的動作卻不一樣。wait:將同步中的線程處于凍結(jié)狀態(tài)。釋放了執(zhí)行權(quán),釋放了資格。同時將線程對象存儲到線程池中。notify:喚醒線程池中某一個等待線程。notifyAll:喚醒的是線程池中的所有線程。些方法都需要定義在同步中。2:因為這些方法必須要標(biāo)示所屬的鎖。因為這三個方法都需要定義同步內(nèi),并標(biāo)示所屬的同步鎖,既然被鎖調(diào)用,而鎖又可以是任意對象,那么wait:可以指定時間也可以不指定時間。不指定時間,只能由對應(yīng)的notify或者notifyAll來喚醒。sleep:必須指定時間,時間到自動從凍結(jié)狀態(tài)轉(zhuǎn)成運行狀態(tài)(臨時阻塞狀態(tài))。Sleep:線程會釋放執(zhí)行權(quán),但不是不釋放鎖。第一種方式:定義循環(huán)的結(jié)束標(biāo)記。第二種方式:如果線程處于了凍結(jié)狀態(tài),是不可能讀到標(biāo)記的,這時就需要通過Thread類中的interrupt方法,將其凍結(jié)狀態(tài)強制清除。讓線程恢復(fù)具備執(zhí)行資格的狀態(tài),讓線程可以讀到標(biāo)記,并結(jié)束。---------<java.lang.Thread>----------interrupt():中斷線程。setPriority(intnewPriority):更改線程的優(yōu)先級。getPriority():返回線程的優(yōu)先級。toString():返回該線程的字符串表示形式,包括線程名稱、優(yōu)先級和線程組。Thread.yield():暫停當(dāng)前正在執(zhí)行的線程對象,并執(zhí)行其他線程。setDaemon(true):將該線程標(biāo)記為守護線程或用戶線程。將該線程標(biāo)記為守護線程或用戶線程。當(dāng)正在運行的-----------------------------------------------------------解決線程安全問題使用同步的形式,(同步代碼塊,要么同步函數(shù))其實最終使用的都是鎖機制。到了后期版本,直接將鎖封裝成了對象。線程進入同步就是具備了鎖,執(zhí)行完,離開同步,就是釋放了鎖。在后期對鎖的分析過程中,發(fā)現(xiàn),獲取鎖,或者釋放鎖的動作應(yīng)該是鎖這個事物更清楚。所以將這些動作定義在了鎖當(dāng)中,并把鎖定義成對象。所以同步是隱示的鎖操作,而Lock對象是顯示的鎖操作,它的出現(xiàn)就替代了同步。在之前的版本中使用Object類中wait、notify、notifyAll的方式來完成的。那是因為同步中的鎖是任意對LockLockLock接ConditionObject中的三個方法進行單獨的封裝。并提供了功能一致的方法await()、signal()、signalAll()體現(xiàn)新版本對象的好<java.util.concurrent.locks>await()、signal()、signalAll();--------------------------------------------------------classBoundedBuffer{finalLocklock=newReentrantLock();finalConditionnotFull=lock.newCondition();finalConditionnotEmpty=lock.newCondition();finalObject[]items=newObject[100];intputptr,takeptr,count;publicvoidput(Objectx)throwsInterruptedException{lock.lock();try{while(count==items.length)notFull.await();items[putptr]=x;if(++putptr==items.length)putptr=0;++count;notEmpty.signal();}finally{lock.unlock();}}publicObjecttake()throwsInterruptedException{lock.lock();try{while(count==0)notEmpty.await();Objectx=items[takeptr];if(++takeptr==items.length)takeptr=0;--count;notFull.signal();returnx;}finally{lock.unlock();}}}------------------------------------------------------------------------------------------------API:(ApplicationProgrammingInterface,編程接口)是一些預(yù)先定義的,目的是提供應(yīng)用程序與開發(fā)人員基于某或硬件的以訪問一組的能力,而又無需訪問源碼,或理解內(nèi)部工作機制的細節(jié)。valangStringringStringsabc;只要是雙引號引起的數(shù)據(jù)都是字符串對象。特點:字符串一旦被初始化,就不可以被改變,存放在方法區(qū)中的常量池中。------------------------------------------------------Strings1="abc";//s1指向的內(nèi)存中只有一個對象abc。Strings2=newString("abc");//s2指向的內(nèi)容中有兩個對象abc、new。System.out.println(s1==s2);//falseSystem.out.println(s1.equals(s2));//true,字符串中equals比較的是字符串內(nèi)容是否相同。-------------------------------------------------------Strings1=newString();//創(chuàng)建了一個空內(nèi)容的字符串。Strings3="";//s3指向一個具體的字符串對象,只不過這個字符串中沒有內(nèi)容。//一般在定義字符串時,不用new。Strings4=newString("abc");Strings5="abc";一般用此寫法newString(char[]);//將字符數(shù)組轉(zhuǎn)成字符串。newString(char[],offset,count);//將字符數(shù)組中的一部分轉(zhuǎn)成字符串。2.1.3:獲取指定字符的位置。如果不存在返回-1,所以可以通過返回值-1來判斷某一個字符不存在的情intindexOf(intch);//返回第一次找到的字符角標(biāo)intindexOf(intch,intfromIndex);//返回從指定位置開始第一次找到的角標(biāo)intindexOf(Stringstr);//返回第一次找到的字符串角標(biāo)intindexOf(Stringstr,intfromIndex);intlastIndexOf(intch);intlastIndexOf(intch,intfromIndex);intlastIndexOf(Stringstr);intlastIndexOf(Stringstr,intfromIndex);串。substring(0,str.length());//獲取整串booleancontains(Stringsubstring);booleanstartsWith(string);booleanendsWith(string);2.2.4:判斷字符串是否相同booleanequalsstringObject字符串內(nèi)容是否相同。2.2.5:判斷字符串內(nèi)容是否相同,忽略大小寫。booleanequalsIgnoreCase(string);2.3.1:通過構(gòu)造函數(shù)可以將字符數(shù)組或者字節(jié)數(shù)組轉(zhuǎn)成字符串。2.3.2:可以通過字符串中的靜態(tài)方法,將字符數(shù)組轉(zhuǎn)成字符串。staticStringcopyValueOf(char[]);staticStringcopyValueOf(char[],intoffset,intcount);staticStringvalueOf(char[]);staticStringvalueOf(char[],intoffset,intcount);2.3.3:將基本數(shù)據(jù)類型或者對象轉(zhuǎn)成字符串。staticStringvalueOf(char);staticStringvalueOf(boolean);staticStringvalueOf(double);staticStringvalueOf(float);staticStringvalueOf(int);staticStringvalueOf(long);staticStringvalueOf(Object);2.3.4:將字符串轉(zhuǎn)成大小寫。StringtoLowerCase();StringtoUpperCase();2.3.5:將字符串轉(zhuǎn)成數(shù)組。char[]toCharArray();//轉(zhuǎn)成字符數(shù)組。byte[]getBytes();//可以加入編碼表。轉(zhuǎn)成字節(jié)數(shù)組。2.3.6:將字符串轉(zhuǎn)成字符串?dāng)?shù)組。切割方法。String[]split(分割的規(guī)則-字符串);2.3.7:將字符串進行內(nèi)容替換。注意:修改后變成新字符串,并不是將原字符串直接修改。Stringreplace(oldChar,newChar);Stringreplace(oldstring,newstring);ingStringtrim();//去除字符串兩端的空格intcompareTo();//如果參數(shù)字符串等于此字符串,則返回值0;如果此字符串按字典順序小于字符串參數(shù),則返回一個小于0的值;如果此字符串按字典順序大于字符串參數(shù),則返回一個大于0------------------------------------------------------------------------------------------------javalang--StringBuffer字符串緩沖區(qū):★★★☆構(gòu)造一個其中不帶字符的字符串緩沖區(qū),初始容量為16個字符。1:可以對字符串內(nèi)容進行修改。4:緩沖區(qū)中可以存儲任意類型的數(shù)據(jù)。5:最終需要變成字符串。StringBufferappend(data):在緩沖區(qū)中追加數(shù)據(jù)。追加到尾部。StringBufferinsert(index,data):在指定位置插入數(shù)據(jù)。StringBufferdeleteCharAt(index);刪除指定位置的元素//sb.delete(0,sb.length());//清空緩沖區(qū)。voidsetCharAt(index,char);替換指定位置的字符voidsetLength(len);將原字符串置為指定長度的字符串intindexOf(string);返回指定子字符串在此字符串中第一次出現(xiàn)處的索引。intindexOf(string,intfromIndex);從指定位置開始查找字符串intlastIndexOf(string);返回指定子字符串在此字符串中最右邊出現(xiàn)處的索引。intlastIndexOf(string,intfromIndex);從指定的索引開始反向搜索StringBufferreverse();字符串反轉(zhuǎn)------------------------------------------------------------------------------------------------javalang>--StringBuilder字符串緩沖區(qū):★★★☆JDK1.5出現(xiàn)StringBuiler;構(gòu)造一個其中不帶字符的字符串生成器,初始容量為16個字符。該類被設(shè)計用作StringBuffer的一個簡易替換,用在字符串緩沖區(qū)被單個線程使用的時候(這種情況很普遍)。StringBuffer和StringBuilder的區(qū)別:單線程操作,使用StringBuilder效率高。ingBuffer---------------------------------------------------------StringBuildersb=newStringBuilder("abcdefg");sb.append("ak");//abcdefgaksb.insert(1,"et");//aetbcdefgsb.deleteCharAt(2);//abdefgsb.delete(2,4);//abefgsb.setLength(4);//abcdsb.setCharAt(0,'k');//kbcdefgsb.replace(0,2,"hhhh");//hhhhcdefg//想要使用緩沖區(qū),先要建立對象。StringBuffersb=newStringBuffer();sb.append(12).append("haha");//方法調(diào)用鏈。Strings="abc"+4+'q';s=newStringBuffer().append("abc").append(4).append('q').toString();---------------------------------------------------------classTest{publicstaticvoidmain(String[]args){Strings1="java";Strings2="hello";method_1(s1,s2);System.out.println(s1+"...."+s2);//java....helloStringBuilders11=newStringBuilder("java");StringBuilders22=newStringBuilder("hello");method_2(s11,s22);System.out.println(s11+"-----"+s22);//javahello-----hello}publicstaticvoidmethod_1(Strings1,Strings2){s1.replace('a','k');s1=s2;}publicstaticvoidmethod_2(StringBuilders1,StringBuilders2){s1.append(s2);s1=s2;}}---------------------------------------------------------象思想將基本數(shù)據(jù)類型封裝成了對象。1:可以通過對象中的屬性和行為操作基本數(shù)據(jù)。2:可以實現(xiàn)基本數(shù)據(jù)類型和字符串之間的轉(zhuǎn)換。鍵字byteuble對應(yīng)的類名paserShort(numstringpaserShort(numstring);hortLongFloatDoubleCharacterBooleanBooleanXXXparseXXX法--------------------------------------------------------數(shù)字格式的字符串轉(zhuǎn)成基本數(shù)據(jù)類型的方法:1:Integer中的靜態(tài)方法StringtoString(int);2:int+"";將一個十進制整數(shù)轉(zhuǎn)成其他進制:toString(intnum,intradix);parseInt(string,radix);//將給定的數(shù)轉(zhuǎn)成指定的基數(shù)進制;在jdk1.5版本后,對基本數(shù)據(jù)類型對象包裝類進行升級。在升級中,使用基本數(shù)據(jù)類型對象包裝類可以像使用基本數(shù)據(jù)類型一樣,進行運算。i=i+5;Integerc=127;Integerd=127;System.out.println(c==d);//true//在裝箱時,如果數(shù)值在byte范圍之內(nèi),那么數(shù)值相同,不會產(chǎn)生新的對象,也就是說多個數(shù)值相同的引用指向的是同一個對象。------------------------------------------------------------------------------------------------2:對象的個數(shù)確定可以使用數(shù)組,但是不確定怎么辦?可以用集合。因為集合是可變長度的。1:數(shù)組是固定長度的;集合可變長度的。2:數(shù)組可以存儲基本數(shù)據(jù)類型,也可以存儲引用數(shù)據(jù)類型;集合只能存儲引用數(shù)據(jù)類型。3:數(shù)組存儲的元素必須是同一個數(shù)據(jù)類型;集合存儲的對象可以是不同數(shù)據(jù)類型。數(shù)據(jù)結(jié)構(gòu):就是容器中存儲數(shù)據(jù)的方式。對于集合容器,有很多種。因為每一個容器的自身特點不同,其實原理在于每個容器的內(nèi)部數(shù)據(jù)結(jié)構(gòu)不同。------------------------------------------------------------Collection:|--List:有序(元素存入集合的順序和取出的順序一致),元素都有索引。元素可以重復(fù)。|--Set:無序(存入和取出順序有可能不一致),不可以存儲重復(fù)元素。必須保證元素唯一性。add(object):添加一個元素addAll(Collection):添加一個集合中的所有元素。removeobj。注意:刪除成功,集合的長度會改變
溫馨提示
- 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)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五版應(yīng)急通訊基站搭棚施工合同參考2篇
- 二零二五版交通事故車輛維修及賠償協(xié)議2篇
- 二零二五年度食品飲料品牌授權(quán)銷售合同范本2篇
- 二零二五年度儲罐安裝與環(huán)保驗收合同4篇
- 2025年度個人理財產(chǎn)品投資及收益分配合同4篇
- 2025年度生物質(zhì)能發(fā)電項目承包清工勞務(wù)合同模板4篇
- 二零二五年度玻璃工藝品設(shè)計與生產(chǎn)合作協(xié)議
- 二零二五年度轉(zhuǎn)租協(xié)議甲乙丙三方權(quán)益保障合同
- 2025年度跨境電商股權(quán)退出撤資協(xié)議書
- 二零二五年度餐廳租賃合同附餐飲行業(yè)趨勢研究合作
- 2025年春新滬科版物理八年級下冊全冊教學(xué)課件
- 2025屆高考語文復(fù)習(xí):散文的結(jié)構(gòu)與行文思路 課件
- 電網(wǎng)調(diào)度基本知識課件
- 拉薩市2025屆高三第一次聯(lián)考(一模)語文試卷(含答案解析)
- 《保密法》培訓(xùn)課件
- 回收二手機免責(zé)協(xié)議書模板
- (正式版)JC∕T 60023-2024 石膏條板應(yīng)用技術(shù)規(guī)程
- (權(quán)變)領(lǐng)導(dǎo)行為理論
- 2024屆上海市浦東新區(qū)高三二模英語卷
- 2024年智慧工地相關(guān)知識考試試題及答案
- GB/T 8005.2-2011鋁及鋁合金術(shù)語第2部分:化學(xué)分析
評論
0/150
提交評論