java基礎(chǔ)知識(shí)點(diǎn)總結(jié)(經(jīng)典)_第1頁(yè)
java基礎(chǔ)知識(shí)點(diǎn)總結(jié)(經(jīng)典)_第2頁(yè)
java基礎(chǔ)知識(shí)點(diǎn)總結(jié)(經(jīng)典)_第3頁(yè)
java基礎(chǔ)知識(shí)點(diǎn)總結(jié)(經(jīng)典)_第4頁(yè)
java基礎(chǔ)知識(shí)點(diǎn)總結(jié)(經(jīng)典)_第5頁(yè)
已閱讀5頁(yè),還剩51頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡(jiǎn)介

...wd......wd......wd...Java根基知識(shí)總結(jié)〔超級(jí)經(jīng)典〕寫代碼:1,明確需求。我要做什么2,分析思路。我要怎么做1,2,3。3,確定步驟。每一個(gè)思路局部用到哪些語(yǔ)句,方法,和對(duì)象。4,代碼實(shí)現(xiàn)。用具體的java語(yǔ)言代碼把思路表達(dá)出來(lái)。學(xué)習(xí)新技術(shù)的四點(diǎn):1,該技術(shù)是什么2,該技術(shù)有什么特點(diǎn)(使用注意):3,該技術(shù)怎么使用。demo4,該技術(shù)什么時(shí)候用test。-----------------------------------------------------------------------------------------------一:java概述:1991年Sun公司的JamesGosling等人開場(chǎng)開發(fā)名稱為Oak的語(yǔ)言,希望用于控制嵌入在有線電視交換盒、PDA等的微處理器;1994年將Oak語(yǔ)言更名為Java;Java的三種技術(shù)架構(gòu):JAVAEE:JavaPlatformEnterpriseEdition,開發(fā)企業(yè)環(huán)境下的應(yīng)用程序,主要針對(duì)web程序開發(fā);JAVASE:JavaPlatformStandardEdition,完成桌面應(yīng)用程序的開發(fā),是其它兩者的根基;JAVAME:JavaPlatformMicroEdition,開發(fā)電子消費(fèi)產(chǎn)品和嵌入式設(shè)備,如手機(jī)中的程序;1,JDK:JavaDevelopmentKit,java的開發(fā)和運(yùn)行環(huán)境,java的開發(fā)工具和jre。2,JRE:JavaRuntimeEnvironment,java程序的運(yùn)行環(huán)境,java運(yùn)行的所需的類庫(kù)+JVM(java虛擬機(jī))。3,配置環(huán)境變量:讓javajdk\bin目錄下的工具,可以在任意目錄下運(yùn)行,原因是,將該工具所在目錄告訴了系統(tǒng),當(dāng)使用該工具時(shí),由系統(tǒng)幫我們?nèi)フ抑付ǖ哪夸?。環(huán)境變量的配置:1〕:永久配置方式:JAVA_HOME=%安裝路徑%\Java\jdkpath=%JAVA_HOME%\bin 2〕:臨時(shí)配置方式:setpath=%path%;C:\ProgramFiles\Java\jdk\bin特點(diǎn):系統(tǒng)默認(rèn)先去當(dāng)前路徑下找要執(zhí)行的程序,如果沒有,再去path中設(shè)置的路徑下找。classpath的配置:1〕:永久配置方式:classpath=.;c:\;e:\ 2〕:臨時(shí)配置方式:setclasspath=.;c:\;e:\注意:在定義classpath環(huán)境變量時(shí),需要注意的情況如果沒有定義環(huán)境變量classpath,java啟動(dòng)jvm后,會(huì)在當(dāng)前目錄下查找要運(yùn)行的類文件;如果指定了classpath,那么會(huì)在指定的目錄下查找要運(yùn)行的類文件。還會(huì)在當(dāng)前目錄找嗎兩種情況: 1〕:如果classpath的值結(jié)尾處有分號(hào),在具體路徑中沒有找到運(yùn)行的類,會(huì)默認(rèn)在當(dāng)前目錄再找一次。 2〕:如果classpath的值結(jié)果出沒有分號(hào),在具體的路徑中沒有找到運(yùn)行的類,不會(huì)再當(dāng)前目錄找。 一般不指定分號(hào),如果沒有在指定目錄下找到要運(yùn)行的類文件,就報(bào)錯(cuò),這樣可以調(diào)試程序。4,javac命令和java命令做什么事情呢 要知道java是分兩局部的:一個(gè)是編譯,一個(gè)是運(yùn)行。javac:負(fù)責(zé)的是編譯的局部,當(dāng)執(zhí)行javac時(shí),會(huì)啟動(dòng)java的編譯器程序。對(duì)指定擴(kuò)展名的.java文件進(jìn)展編譯。生成了jvm可以識(shí)別的字節(jié)碼文件。也就是class文件,也就是java的運(yùn)行程序。java:負(fù)責(zé)運(yùn)行的局部.會(huì)啟動(dòng)jvm.加載運(yùn)行時(shí)所需的類庫(kù),并對(duì)class文件進(jìn)展執(zhí)行. 一個(gè)文件要被執(zhí)行,必須要有一個(gè)執(zhí)行的起始點(diǎn),這個(gè)起始點(diǎn)就是main函數(shù).----------------------------------------------------------------------------------------------二:java語(yǔ)法根基:1,關(guān)鍵字:其實(shí)就是某種語(yǔ)言賦予了特殊含義的單詞。 保存字:其實(shí)就是還沒有賦予特殊含義,但是準(zhǔn)備日后要使用過的單詞。2,標(biāo)示符:其實(shí)就是在程序中自定義的名詞。比方類名,變量名,函數(shù)名。包含0-9、a-z、$、_; 注意:1〕,數(shù)字不可以開頭。 2〕,不可以使用關(guān)鍵字。3,常量:是在程序中的不會(huì)變化的數(shù)據(jù)。4,變量:其實(shí)就是內(nèi)存中的一個(gè)存儲(chǔ)空間,用于存儲(chǔ)常量數(shù)據(jù)。 作用:方便于運(yùn)算。因?yàn)橛行?shù)據(jù)不確定。所以確定該數(shù)據(jù)的名詞和存儲(chǔ)空間。 特點(diǎn):變量空間可以重復(fù)使用。什么時(shí)候定義變量只要是數(shù)據(jù)不確定的時(shí)候,就定義變量。變量空間的開辟需要什么要素呢 1,這個(gè)空間要存儲(chǔ)什么數(shù)據(jù)數(shù)據(jù)類型。 2,這個(gè)空間叫什么名字啊變量名稱。 3,這個(gè)空間的第一次的數(shù)據(jù)是什么變量的初始化值。變量的作用域和生存期:變量的作用域:作用域從變量定義的位置開場(chǎng),到該變量所在的那對(duì)大括號(hào)完畢;生命周期:變量從定義的位置開場(chǎng)就在內(nèi)存中活了;變量到達(dá)它所在的作用域的時(shí)候就在內(nèi)存中消失了;數(shù)據(jù)類型:1〕:基本數(shù)據(jù)類型:byte、short、int、long、float、double、char、boolean2〕:引用數(shù)據(jù)類型:數(shù)組、類、接口。級(jí)別從低到高為:byte,char,short(這三個(gè)平級(jí))-->int-->float-->long-->double自動(dòng)類型轉(zhuǎn)換:從低級(jí)別到高級(jí)別,系統(tǒng)自動(dòng)轉(zhuǎn)的;強(qiáng)制類型轉(zhuǎn)換:什么情況下使用?把一個(gè)高級(jí)別的數(shù)賦給一個(gè)別該數(shù)的級(jí)別低的變量;運(yùn)算符號(hào): 1〕、算術(shù)運(yùn)算符。 +-*/%%:任何整數(shù)模2不是0就是1,所以只要改變被模數(shù)就可以實(shí)現(xiàn)開關(guān)運(yùn)算。 +:連接符。 ++,-- 2〕、賦值運(yùn)算符。 =+=-=*=/=%= 3〕、比較運(yùn)算符。 特點(diǎn):該運(yùn)算符的特點(diǎn)是:運(yùn)算完的結(jié)果,要么是true,要么是false。 4〕、邏輯運(yùn)算符。 &|^!&&|| 邏輯運(yùn)算符除了!外都是用于連接兩個(gè)boolean類型表達(dá)式。 &:只有兩邊都為true結(jié)果是true。否那么就是false。 |:只要兩邊都為false結(jié)果是false,否那么就是true ^:異或:和或有點(diǎn)不一樣。 兩邊結(jié)果一樣,就為false。 兩邊結(jié)果不一樣,就為true.&和&&區(qū)別:&:無(wú)論左邊結(jié)果是什么,右邊都參與運(yùn)算。&&:短路與,如果左邊為false,那么右邊不參數(shù)與運(yùn)算。|和||區(qū)別:|:兩邊都運(yùn)算。||:短路或,如果左邊為true,那么右邊不參與運(yùn)算。 5〕、位運(yùn)算符:用于操作二進(jìn)制位的運(yùn)算符。 &|^ <<>>>>>(無(wú)符號(hào)右移)練習(xí):對(duì)兩個(gè)變量的數(shù)據(jù)進(jìn)展互換。不需要第三方變量。 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í):高效的算出2*8=2<<3;5,語(yǔ)句。 Ifswitchdowhilewhilefor 這些語(yǔ)句什么時(shí)候用 1〕、當(dāng)判斷固定個(gè)數(shù)的值的時(shí)候,可以使用if,也可以使用switch。 但是建議使用switch,效率相對(duì)較高。switch(變量){ case值:要執(zhí)行的語(yǔ)句;break;… default:要執(zhí)行的語(yǔ)句;}工作原理:用小括號(hào)中的變量的值依次和case后面的值進(jìn)展比照,和哪個(gè)case后面的值一樣了就執(zhí)行哪個(gè)case后面的語(yǔ)句,如果沒有一樣的那么執(zhí)行default后面的語(yǔ)句;細(xì)節(jié):1〕:break是可以省略的,如果省略了就一直執(zhí)行到遇到break為止; 2〕:switch后面的小括號(hào)中的變量應(yīng)該是byte,char,short,int四種類型中的一種; 3〕:default可以寫在switch構(gòu)造中的任意位置;如果將default語(yǔ)句放在了第一行,那么不管expression與case中的value是否匹配,程序會(huì)從default開場(chǎng)執(zhí)行直到第一個(gè)break出現(xiàn)。 2〕、當(dāng)判斷數(shù)據(jù)范圍,獲取判斷運(yùn)算結(jié)果boolean類型時(shí),需要使用if。 3〕、當(dāng)某些語(yǔ)句需要執(zhí)行很屢次時(shí),就用循環(huán)構(gòu)造。 while和for可以進(jìn)展互換。 區(qū)別在于:如果需要定義變量控制循環(huán)次數(shù)。建議使用for。因?yàn)閒or循環(huán)完畢,變量在內(nèi)存中釋放。break:作用于switch,和循環(huán)語(yǔ)句,用于跳出,或者稱為完畢。break語(yǔ)句單獨(dú)存在時(shí),下面不要定義其他語(yǔ)句,因?yàn)閳?zhí)行不到,編譯會(huì)失敗。當(dāng)循環(huán)嵌套時(shí),break只跳出當(dāng)前所在循環(huán)。要跳出嵌套中的外部循環(huán),只要給循環(huán)起名字即可,這個(gè)名字稱之為標(biāo)號(hào)。continue:只作用于循環(huán)構(gòu)造,繼續(xù)循環(huán)用的。作用:完畢本次循環(huán),繼續(xù)下次循環(huán)。該語(yǔ)句單獨(dú)存在時(shí),下面不可以定義語(yǔ)句,執(zhí)行不到。6,函數(shù):為了提高代碼的復(fù)用性,可以將其定義成一個(gè)單獨(dú)的功能,該功能的表達(dá)就是java中的函數(shù)。函數(shù)就是表達(dá)之一。java中的函數(shù)的定義格式:修飾符返回值類型函數(shù)名(參數(shù)類型形式參數(shù)1,參數(shù)類型形式參數(shù)1,…){ 執(zhí)行語(yǔ)句; return返回值; }當(dāng)函數(shù)沒有具體的返回值時(shí),返回的返回值類型用void關(guān)鍵字表示。如果函數(shù)的返回值類型是void時(shí),return語(yǔ)句可以省略不寫的,系統(tǒng)會(huì)幫你自動(dòng)加上。return的作用:完畢函數(shù)。完畢功能。如何定義一個(gè)函數(shù) 函數(shù)其實(shí)就是一個(gè)功能,定義函數(shù)就是實(shí)現(xiàn)功能,通過兩個(gè)明確來(lái)完成: 1〕、明確該功能的運(yùn)算完的結(jié)果,其實(shí)是在明確這個(gè)函數(shù)的返回值類型。 2〕、在實(shí)現(xiàn)該功能的過程中是否有未知內(nèi)容參與了運(yùn)算,其實(shí)就是在明確這個(gè)函數(shù)的參數(shù)列表(參數(shù)類型&參數(shù)個(gè)數(shù))。函數(shù)的作用:1〕、用于定義功能。2〕、用于封裝代碼提高代碼的復(fù)用性。注意:函數(shù)中只能調(diào)用函數(shù),不能定義函數(shù)。主函數(shù): 1〕、保證該類的獨(dú)立運(yùn)行。 2〕、因?yàn)樗浅绦虻娜肟凇?3〕、因?yàn)樗诒籮vm調(diào)用。函數(shù)定義名稱是為什么呢答:1〕、為了對(duì)該功能進(jìn)展標(biāo)示,方便于調(diào)用。 2〕、為了通過名稱就可以明確函數(shù)的功能,為了增加代碼的閱讀性。重載的定義是:在一個(gè)類中,如果出現(xiàn)了兩個(gè)或者兩個(gè)以上的同名函數(shù),只要它們的參數(shù)的個(gè)數(shù),或者參數(shù)的類型不同,即可稱之為該函數(shù)重載了。如何區(qū)分重載:當(dāng)函數(shù)同名時(shí),只看參數(shù)列表。和返回值類型沒關(guān)系。7,數(shù)組:用于存儲(chǔ)同一類型數(shù)據(jù)的一個(gè)容器。好處:可以對(duì)該容器中的數(shù)據(jù)進(jìn)展編號(hào),從0開場(chǎng)。數(shù)組用于封裝數(shù)據(jù),就是一個(gè)具體的實(shí)體。如何在java中表現(xiàn)一個(gè)數(shù)組呢兩種表現(xiàn)形式。1〕、元素類型[]變量名=new元素類型[元素的個(gè)數(shù)];2〕、元素類型[]變量名={元素1,元素2...};元素類型[]變量名=new元素類型[]{元素1,元素2...};---------------------------------------------------------//二分查找法。必須有前提:數(shù)組中的元素要有序。 publicstaticinthalfSeach_2(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(key<arr[mid]) max=mid-1; if(max<min) return-1; mid=(max+min)>>1; } returnmid; }---------------------------------------------------------java分了5片內(nèi)存。1:存放器。2:本地方法區(qū)。3:方法區(qū)。4:棧。5:堆。棧:存儲(chǔ)的都是局部變量(函數(shù)中定義的變量,函數(shù)上的參數(shù),語(yǔ)句中的變量); 只要數(shù)據(jù)運(yùn)算完成所在的區(qū)域完畢,該數(shù)據(jù)就會(huì)被釋放。堆:用于存儲(chǔ)數(shù)組和對(duì)象,也就是實(shí)體。啥是實(shí)體啊就是用于封裝多個(gè)數(shù)據(jù)的。1:每一個(gè)實(shí)體都有內(nèi)存首地址值。2:堆內(nèi)存中的變量都有默認(rèn)初始化值。因?yàn)閿?shù)據(jù)類型不同,值也不一樣。3:垃圾回收機(jī)制。----------------------------------------------------------------------------------------------三:面向?qū)ο螅骸铩铩铩铩锾攸c(diǎn):1:將復(fù)雜的事情簡(jiǎn)單化。2:面向?qū)ο髮⒁郧暗倪^程中的執(zhí)行者,變成了指揮者。3:面向?qū)ο筮@種思想是符合現(xiàn)在人們思考習(xí)慣的一種思想。過程和對(duì)象在我們的程序中是如何表達(dá)的呢過程其實(shí)就是函數(shù);對(duì)象是將函數(shù)等一些內(nèi)容進(jìn)展了封裝。匿名對(duì)象使用場(chǎng)景:1:當(dāng)對(duì)方法只進(jìn)展一次調(diào)用的時(shí)候,可以使用匿名對(duì)象。2:當(dāng)對(duì)象對(duì)成員進(jìn)展屢次調(diào)用時(shí),不能使用匿名對(duì)象。必須給對(duì)象起名字。在類中定義其實(shí)都稱之為成員。成員有兩種:1:成員變量:其實(shí)對(duì)應(yīng)的就是事物的屬性。2:成員函數(shù):其實(shí)對(duì)應(yīng)的就是事物的行為。所以,其實(shí)定義類,就是在定義成員變量和成員函數(shù)。但是在定義前,必須先要對(duì)事物進(jìn)展屬性和行為的分析,才可以用代碼來(lái)表達(dá)。privateintage;//私有的訪問權(quán)限最低,只有在本類中的訪問有效。注意:私有僅僅是封裝的一種表達(dá)形式而已。私有的成員:其他類不能直接創(chuàng)立對(duì)象訪問,所以只有通過本類對(duì)外提供具體的訪問方式來(lái)完成對(duì)私有的訪問,可以通過對(duì)外提供函數(shù)的形式對(duì)其進(jìn)展訪問。好處:可以在函數(shù)中參加邏輯判斷等操作,對(duì)數(shù)據(jù)進(jìn)展判斷等操作??偨Y(jié):開發(fā)時(shí),記住,屬性是用于存儲(chǔ)數(shù)據(jù)的,直接被訪問,容易出現(xiàn)安全隱患,所以,類中的屬性通常被私有化,并對(duì)外提供公共的訪問方法。這個(gè)方法一般有兩個(gè),標(biāo)準(zhǔn)寫法:對(duì)于屬性xxx,可以使用setXXX(),getXXX()對(duì)其進(jìn)展操作。類中怎么沒有定義主函數(shù)呢注意:主函數(shù)的存在,僅為該類是否需要獨(dú)立運(yùn)行,如果不需要,主函數(shù)是不用定義的。主函數(shù)的解釋:保證所在類的獨(dú)立運(yùn)行,是程序的入口,被jvm調(diào)用。成員變量和局部變量的區(qū)別:1:成員變量直接定義在類中。局部變量定義在方法中,參數(shù)上,語(yǔ)句中。2:成員變量在這個(gè)類中有效。局部變量只在自己所屬的大括號(hào)內(nèi)有效,大括號(hào)完畢,局部變量失去作用域。3:成員變量存在于堆內(nèi)存中,隨著對(duì)象的產(chǎn)生而存在,消失而消失。局部變量存在于棧內(nèi)存中,隨著所屬區(qū)域的運(yùn)行而存在,完畢而釋放。構(gòu)造函數(shù):用于給對(duì)象進(jìn)展初始化,是給與之對(duì)應(yīng)的對(duì)象進(jìn)展初始化,它具有針對(duì)性,函數(shù)中的一種。特點(diǎn):1:該函數(shù)的名稱和所在類的名稱一樣。2:不需要定義返回值類型。3:該函數(shù)沒有具體的返回值。記?。核袑?duì)象創(chuàng)立時(shí),都需要初始化才可以使用。本卷須知:一個(gè)類在定義時(shí),如果沒有定義過構(gòu)造函數(shù),那么該類中會(huì)自動(dòng)生成一個(gè)空參數(shù)的構(gòu)造函數(shù),為了方便該類創(chuàng)立對(duì)象,完成初始化。如果在類中自定義了構(gòu)造函數(shù),那么默認(rèn)的構(gòu)造函數(shù)就沒有了。一個(gè)類中,可以有多個(gè)構(gòu)造函數(shù),因?yàn)樗鼈兊暮瘮?shù)名稱都一樣,所以只能通過參數(shù)列表來(lái)區(qū)分。所以,一個(gè)類中如果出現(xiàn)多個(gè)構(gòu)造函數(shù)。它們的存在是以重載表達(dá)的。構(gòu)造函數(shù)和一般函數(shù)有什么區(qū)別呢1:兩個(gè)函數(shù)定義格式不同。2:構(gòu)造函數(shù)是在對(duì)象創(chuàng)立時(shí),就被調(diào)用,用于初始化,而且初始化動(dòng)作只執(zhí)行一次。一般函數(shù),是對(duì)象創(chuàng)立后,需要調(diào)用才執(zhí)行,可以被調(diào)用屢次。什么時(shí)候使用構(gòu)造函數(shù)呢分析事物時(shí),發(fā)現(xiàn)具體事物一出現(xiàn),就具備了一些特征,那就將這些特征定義到構(gòu)造函數(shù)內(nèi)。構(gòu)造代碼塊和構(gòu)造函數(shù)有什么區(qū)別構(gòu)造代碼塊:是給所有的對(duì)象進(jìn)展初始化,也就是說,所有的對(duì)象都會(huì)調(diào)用一個(gè)代碼塊。只要對(duì)象一建設(shè)。就會(huì)調(diào)用這個(gè)代碼塊。構(gòu)造函數(shù):是給與之對(duì)應(yīng)的對(duì)象進(jìn)展初始化。它具有針對(duì)性。Personp=newPerson();創(chuàng)立一個(gè)對(duì)象都在內(nèi)存中做了什么事情1:先將硬盤上指定位置的Person.class文件加載進(jìn)內(nèi)存。2:執(zhí)行main方法時(shí),在棧內(nèi)存中開辟了main方法的空間(壓棧-進(jìn)棧),然后在main方法的棧區(qū)分配了一個(gè)變量p。3:在堆內(nèi)存中開辟一個(gè)實(shí)體空間,分配了一個(gè)內(nèi)存首地址值。new4:在該實(shí)體空間中進(jìn)展屬性的空間分配,并進(jìn)展了默認(rèn)初始化。5:對(duì)空間中的屬性進(jìn)展顯示初始化。6:進(jìn)展實(shí)體的構(gòu)造代碼塊初始化。7:調(diào)用該實(shí)體對(duì)應(yīng)的構(gòu)造函數(shù),進(jìn)展構(gòu)造函數(shù)初始化?!病?:將首地址賦值給p,p變量就引用了該實(shí)體。(指向了該對(duì)象)--------------------------------------------------------------------------------------------封裝〔面向?qū)ο筇卣髦弧常菏侵鸽[藏對(duì)象的屬性和實(shí)現(xiàn)細(xì)節(jié),僅對(duì)外提供公共訪問方式。好處:將變化隔離;便于使用;提高重用性;安全性。封裝原那么:將不需要對(duì)外提供的內(nèi)容都隱藏起來(lái),把屬性都隱藏,提供公共方法對(duì)其訪問。this:代表對(duì)象。就是所在函數(shù)所屬對(duì)象的引用。this到底代表什么呢哪個(gè)對(duì)象調(diào)用了this所在的函數(shù),this就代表哪個(gè)對(duì)象,就是哪個(gè)對(duì)象的引用。開發(fā)時(shí),什么時(shí)候使用this呢在定義功能時(shí),如果該功能內(nèi)部使用到了調(diào)用該功能的對(duì)象,這時(shí)就用this來(lái)表示這個(gè)對(duì)象。this還可以用于構(gòu)造函數(shù)間的調(diào)用。調(diào)用格式:this(實(shí)際參數(shù));this對(duì)象后面跟上.調(diào)用的是成員屬性和成員方法(一般方法);this對(duì)象后面跟上()調(diào)用的是本類中的對(duì)應(yīng)參數(shù)的構(gòu)造函數(shù)。注意:用this調(diào)用構(gòu)造函數(shù),必須定義在構(gòu)造函數(shù)的第一行。因?yàn)闃?gòu)造函數(shù)是用于初始化的,所以初始化動(dòng)作一定要執(zhí)行。否那么編譯失敗。static:★★★關(guān)鍵字,是一個(gè)修飾符,用于修飾成員(成員變量和成員函數(shù))。特點(diǎn):1,想要實(shí)現(xiàn)對(duì)象中的共性數(shù)據(jù)的對(duì)象共享??梢詫⑦@個(gè)數(shù)據(jù)進(jìn)展靜態(tài)修飾。2,被靜態(tài)修飾的成員,可以直接被類名所調(diào)用。也就是說,靜態(tài)的成員多了一種調(diào)用方式。類名.靜態(tài)方式。3,靜態(tài)隨著類的加載而加載。而且優(yōu)先于對(duì)象存在。弊端:1,有些數(shù)據(jù)是對(duì)象特有的數(shù)據(jù),是不可以被靜態(tài)修飾的。因?yàn)槟菢拥脑挘赜袛?shù)據(jù)會(huì)變成對(duì)象的共享數(shù)據(jù)。這樣對(duì)事物的描述就出了問題。所以,在定義靜態(tài)時(shí),必須要明確,這個(gè)數(shù)據(jù)是否是被對(duì)象所共享的。2,靜態(tài)方法只能訪問靜態(tài)成員,不可以訪問非靜態(tài)成員。因?yàn)殪o態(tài)方法加載時(shí),優(yōu)先于對(duì)象存在,所以沒有方法訪問對(duì)象中的成員。3,靜態(tài)方法中不能使用this,super關(guān)鍵字。因?yàn)閠his代表對(duì)象,而靜態(tài)在時(shí),有可能沒有對(duì)象,所以this無(wú)法使用。4,主函數(shù)是靜態(tài)的。什么時(shí)候定義靜態(tài)成員呢或者說:定義成員時(shí),到底需不需要被靜態(tài)修飾呢成員分兩種:1,成員變量?!矓?shù)據(jù)共享時(shí)靜態(tài)化〕該成員變量的數(shù)據(jù)是否是所有對(duì)象都一樣:如果是,那么該變量需要被靜態(tài)修飾,因?yàn)槭枪蚕淼臄?shù)據(jù)。如果不是,那么就說這是對(duì)象的特有數(shù)據(jù),要存儲(chǔ)到對(duì)象中。2,成員函數(shù)?!卜椒ㄖ袥]有調(diào)用特有數(shù)據(jù)時(shí)就定義成靜態(tài)〕 如果判斷成員函數(shù)是否需要被靜態(tài)修飾呢 只要參考,該函數(shù)內(nèi)是否訪問了對(duì)象中的特有數(shù)據(jù): 如果有訪問特有數(shù)據(jù),那方法不能被靜態(tài)修飾。 如果沒有訪問過特有數(shù)據(jù),那么這個(gè)方法需要被靜態(tài)修飾。成員變量和靜態(tài)變量的區(qū)別:1,成員變量所屬于對(duì)象。所以也稱為實(shí)例變量。靜態(tài)變量所屬于類。所以也稱為類變量。2,成員變量存在于堆內(nèi)存中。靜態(tài)變量存在于方法區(qū)中。3,成員變量隨著對(duì)象創(chuàng)立而存在。隨著對(duì)象被回收而消失。靜態(tài)變量隨著類的加載而存在。隨著類的消失而消失。4,成員變量只能被對(duì)象所調(diào)用。靜態(tài)變量可以被對(duì)象調(diào)用,也可以被類名調(diào)用。所以,成員變量可以稱為對(duì)象的特有數(shù)據(jù),靜態(tài)變量稱為對(duì)象的共享數(shù)據(jù)。靜態(tài)的注意:靜態(tài)的生命周期很長(zhǎng)。靜態(tài)代碼塊:就是一個(gè)有靜態(tài)關(guān)鍵字標(biāo)示的一個(gè)代碼塊區(qū)域。定義在類中。作用:可以完成類的初始化。靜態(tài)代碼塊隨著類的加載而執(zhí)行,而且只執(zhí)行一次〔new多個(gè)對(duì)象就只執(zhí)行一次〕。如果和主函數(shù)在同一類中,優(yōu)先于主函數(shù)執(zhí)行。Public:訪問權(quán)限最大。static:不需要對(duì)象,直接類名即可。void:主函數(shù)沒有返回值。Main:主函數(shù)特定的名稱。(String[]args):主函數(shù)的參數(shù),是一個(gè)字符串?dāng)?shù)組類型的參數(shù),jvm調(diào)用main方法時(shí),傳遞的實(shí)際參數(shù)是newString[0]。jvm默認(rèn)傳遞的是長(zhǎng)度為0的字符串?dāng)?shù)組,我們?cè)谶\(yùn)行該類時(shí),也可以指定具體的參數(shù)進(jìn)展傳遞。可以在控制臺(tái),運(yùn)行該類時(shí),在后面參加參數(shù)。參數(shù)之間通過空格隔開。jvm會(huì)自動(dòng)將這些字符串參數(shù)作為args數(shù)組中的元素,進(jìn)展存儲(chǔ)。靜態(tài)代碼塊、構(gòu)造代碼塊、構(gòu)造函數(shù)同時(shí)存在時(shí)的執(zhí)行順序:靜態(tài)代碼塊構(gòu)造代碼塊構(gòu)造函數(shù);生成Java幫助文檔:命令格式:javadoc–d文件夾名–auther–version*.java/**//格式*類描述*@author作者名*@version版本號(hào)*//***方法描述*@param參數(shù)描述*@return返回值描述*/---------------------------------------------------------------------------------------------設(shè)計(jì)模式:解決問題最行之有效的思想。是一套被反復(fù)使用、多數(shù)人知曉的、經(jīng)過分類編目的、代碼設(shè)計(jì)經(jīng)歷的總結(jié)。使用設(shè)計(jì)模式是為了可重用代碼、讓代碼更容易被他人理解、保證代碼可靠性。java中有23種設(shè)計(jì)模式:?jiǎn)卫O(shè)計(jì)模式:★★★★★解決的問題:保證一個(gè)類在內(nèi)存中的對(duì)象唯一性。比方:多程序讀取一個(gè)配置文件時(shí),建議配置文件封裝成對(duì)象。會(huì)方便操作其中數(shù)據(jù),又要保證多個(gè)程序讀到的是同一個(gè)配置文件對(duì)象,就需要該配置文件對(duì)象在內(nèi)存中是唯一的。Runtime()方法就是單例設(shè)計(jì)模式進(jìn)展設(shè)計(jì)的。如何保證對(duì)象唯一性呢思想:1,不讓其他程序創(chuàng)立該類對(duì)象。2,在本類中創(chuàng)立一個(gè)本類對(duì)象。3,對(duì)外提供方法,讓其他程序獲取這個(gè)對(duì)象。步驟:1,因?yàn)閯?chuàng)立對(duì)象都需要構(gòu)造函數(shù)初始化,只要將本類中的構(gòu)造函數(shù)私有化,其他程序就無(wú)法再創(chuàng)立該類對(duì)象;2,就在類中創(chuàng)立一個(gè)本類的對(duì)象;3,定義一個(gè)方法,返回該對(duì)象,讓其他程序可以通過方法就得到本類對(duì)象?!沧饔茫嚎煽亍炒a表達(dá):1,私有化構(gòu)造函數(shù);2,創(chuàng)立私有并靜態(tài)的本類對(duì)象;3,定義公有并靜態(tài)的方法,返回該對(duì)象。---------------------------------------------//餓漢式classSingle{ privateSingle(){}//私有化構(gòu)造函數(shù)。privatestaticSingles=newSingle();//創(chuàng)立私有并靜態(tài)的本類對(duì)象。 publicstaticSinglegetInstance(){//定義公有并靜態(tài)的方法,返回該對(duì)象。 returns; }}---------------------------------------------//懶漢式:延遲加載方式。classSingle2{ privateSingle2(){}privatestaticSingle2s=null; publicstaticSingle2getInstance(){ if(s==null) s=newSingle2(); returns; }}-------------------------------------------------------------------------------------------------繼承〔面向?qū)ο筇卣髦弧澈锰帲?:提高了代碼的復(fù)用性。2:讓類與類之間產(chǎn)生了關(guān)系,提供了另一個(gè)特征多態(tài)的前提。父類的由來(lái):其實(shí)是由多個(gè)類不斷向上抽取共性內(nèi)容而來(lái)的。java中對(duì)于繼承,java只支持單繼承。java雖然不直接支持多繼承,但是保存了這種多繼承機(jī)制,進(jìn)展改良。單繼承:一個(gè)類只能有一個(gè)父類。多繼承:一個(gè)類可以有多個(gè)父類。為什么不支持多繼承呢因?yàn)楫?dāng)一個(gè)類同時(shí)繼承兩個(gè)父類時(shí),兩個(gè)父類中有一樣的功能,那么子類對(duì)象調(diào)用該功能時(shí),運(yùn)行哪一個(gè)呢因?yàn)楦割愔械姆椒ㄖ写嬖诜椒w。但是java支持多重繼承。A繼承BB繼承CC繼承D。多重繼承的出現(xiàn),就有了繼承體系。體系中的頂層父類是通過不斷向上抽取而來(lái)的。它里面定義的該體系最基本最共性內(nèi)容的功能。所以,一個(gè)體系要想被使用,直接查閱該系統(tǒng)中的父類的功能即可知道該體系的基本用法。那么想要使用一個(gè)體系時(shí),需要建設(shè)對(duì)象。建議建設(shè)最子類對(duì)象,因?yàn)樽钭宇惒粌H可以使用父類中的功能。還可以使用子類特有的一些功能。簡(jiǎn)單說:對(duì)于一個(gè)繼承體系的使用,查閱頂層父類中的內(nèi)容,創(chuàng)立最底層子類的對(duì)象。子父類出現(xiàn)后,類中的成員都有了哪些特點(diǎn):1:成員變量。 當(dāng)子父類中出現(xiàn)一樣的屬性時(shí),子類類型的對(duì)象,調(diào)用該屬性,值是子類的屬性值。 如果想要調(diào)用父類中的屬性值,需要使用一個(gè)關(guān)鍵字:superThis:代表是本類類型的對(duì)象引用。Super:代表是子類所屬的父類中的內(nèi)存空間引用。 注意:子父類中通常是不會(huì)出現(xiàn)同名成員變量的,因?yàn)楦割愔兄灰x了,子類就不用在定義了,直接繼承過來(lái)用就可以了。2:成員函數(shù)。當(dāng)子父類中出現(xiàn)了一模一樣的方法時(shí),建設(shè)子類對(duì)象會(huì)運(yùn)行子類中的方法。好似父類中的方法被覆蓋掉一樣。所以這種情況,是函數(shù)的另一個(gè)特性:覆蓋(復(fù)寫,重寫)什么時(shí)候使用覆蓋呢當(dāng)一個(gè)類的功能內(nèi)容需要修改時(shí),可以通過覆蓋來(lái)實(shí)現(xiàn)。3:構(gòu)造函數(shù)。發(fā)現(xiàn)子類構(gòu)造函數(shù)運(yùn)行時(shí),先運(yùn)行了父類的構(gòu)造函數(shù)。為什么呢?原因:子類的所有構(gòu)造函數(shù)中的第一行,其實(shí)都有一條隱身的語(yǔ)句super();super():表示父類的構(gòu)造函數(shù),并會(huì)調(diào)用于參數(shù)相對(duì)應(yīng)的父類中的構(gòu)造函數(shù)。而super():是在調(diào)用父類中空參數(shù)的構(gòu)造函數(shù)。為什么子類對(duì)象初始化時(shí),都需要調(diào)用父類中的函數(shù)(為什么要在子類構(gòu)造函數(shù)的第一行參加這個(gè)super()?)因?yàn)樽宇惱^承父類,會(huì)繼承到父類中的數(shù)據(jù),所以必須要看父類是如何對(duì)自己的數(shù)據(jù)進(jìn)展初始化的。所以子類在進(jìn)展對(duì)象初始化時(shí),先調(diào)用父類的構(gòu)造函數(shù),這就是子類的實(shí)例化過程。注意:子類中所有的構(gòu)造函數(shù)都會(huì)默認(rèn)訪問父類中的空參數(shù)的構(gòu)造函數(shù),因?yàn)槊恳粋€(gè)子類構(gòu)造內(nèi)第一行都有默認(rèn)的語(yǔ)句super();如果父類中沒有空參數(shù)的構(gòu)造函數(shù),那么子類的構(gòu)造函數(shù)內(nèi),必須通過super語(yǔ)句指定要訪問的父類中的構(gòu)造函數(shù)。如果子類構(gòu)造函數(shù)中用this來(lái)指定調(diào)用子類自己的構(gòu)造函數(shù),那么被調(diào)用的構(gòu)造函數(shù)也一樣會(huì)訪問父類中的構(gòu)造函數(shù)。問題:super()和this()是否可以同時(shí)出現(xiàn)的構(gòu)造函數(shù)中。兩個(gè)語(yǔ)句只能有一個(gè)定義在第一行,所以只能出現(xiàn)其中一個(gè)。super()或者this():為什么一定要定義在第一行因?yàn)閟uper()或者this()都是調(diào)用構(gòu)造函數(shù),構(gòu)造函數(shù)用于初始化,所以初始化的動(dòng)作要先完成。繼承的細(xì)節(jié):什么時(shí)候使用繼承呢當(dāng)類與類之間存在著所屬關(guān)系時(shí),才具備了繼承的前提。a是b中的一種。a繼承b。狼是犬科中的一種。英文書中,所屬關(guān)系:"isa"注意:不要僅僅為了獲取其他類中的已有成員進(jìn)展繼承。所以判斷所屬關(guān)系,可以簡(jiǎn)單看,如果繼承后,被繼承的類中的功能,都可以被該子類所具備,那么繼承成立。如果不是,不可以繼承。細(xì)節(jié)二:在方法覆蓋時(shí),注意兩點(diǎn):1:子類覆蓋父類時(shí),必須要保證,子類方法的權(quán)限必須大于等于父類方法權(quán)限可以實(shí)現(xiàn)繼承。否那么,編譯失敗。2:覆蓋時(shí),要么都靜態(tài),要么都不靜態(tài)。(靜態(tài)只能覆蓋靜態(tài),或者被靜態(tài)覆蓋)繼承的一個(gè)弊端:打破了封裝性。對(duì)于一些類,或者類中功能,是需要被繼承,或者復(fù)寫的。這時(shí)如何解決問題呢介紹一個(gè)關(guān)鍵字,final:最終。final特點(diǎn):1:這個(gè)關(guān)鍵字是一個(gè)修飾符,可以修飾類,方法,變量。2:被final修飾的類是一個(gè)最終類,不可以被繼承。3:被final修飾的方法是一個(gè)最終方法,不可以被覆蓋。4:被final修飾的變量是一個(gè)常量,只能賦值一次。 其實(shí)這樣的原因的就是給一些固定的數(shù)據(jù)起個(gè)閱讀性較強(qiáng)的名稱。 不加final修飾不是也可以使用嗎那么這個(gè)值是一個(gè)變量,是可以更改的。加了final,程序更為嚴(yán)謹(jǐn)。常量名稱定義時(shí),有標(biāo)準(zhǔn),所有字母都大寫,如果由多個(gè)單詞組成,中間用_連接。抽象類:abstract抽象:不具體,看不明白。抽象類表象表達(dá)。在不斷抽取過程中,將共性內(nèi)容中的方法聲明抽取,但是方法不一樣,沒有抽取,這時(shí)抽取到的方法,并不具體,需要被指定關(guān)鍵字abstract所標(biāo)示,聲明為抽象方法。抽象方法所在類一定要標(biāo)示為抽象類,也就是說該類需要被abstract關(guān)鍵字所修飾。抽象類的特點(diǎn):1:抽象方法只能定義在抽象類中,抽象類和抽象方法必須由abstract關(guān)鍵字修飾〔可以描述類和方法,不可以描述變量〕。2:抽象方法只定義方法聲明,并不定義方法實(shí)現(xiàn)。3:抽象類不可以被創(chuàng)立對(duì)象(實(shí)例化)。4:只有通過子類繼承抽象類并覆蓋了抽象類中的所有抽象方法后,該子類才可以實(shí)例化。否那么,該子類還是一個(gè)抽象類。抽象類的細(xì)節(jié):1:抽象類中是否有構(gòu)造函數(shù)有,用于給子類對(duì)象進(jìn)展初始化。2:抽象類中是否可以定義非抽象方法可以。其實(shí),抽象類和一般類沒有太大的區(qū)別,都是在描述事物,只不過抽象類在描述事物時(shí),有些功能不具體。所以抽象類和一般類在定義上,都是需要定義屬性和行為的。只不過,比一般類多了一個(gè)抽象函數(shù)。而且比一般類少了一個(gè)創(chuàng)立對(duì)象的局部。3:抽象關(guān)鍵字abstract和哪些不可以共存final, private,static4:抽象類中可不可以不定義抽象方法可以。抽象方法目的僅僅為了不讓該類創(chuàng)立對(duì)象。-----------------------------------------------------------------------------------------------模板方法設(shè)計(jì)模式:解決的問題:當(dāng)功能內(nèi)部一局部實(shí)現(xiàn)時(shí)確定,一局部實(shí)現(xiàn)是不確定的。這時(shí)可以把不確定的局部暴露出去,讓子類去實(shí)現(xiàn)。abstractclassGetTime{ publicfinalvoidgetTime(){//此功能如果不需要復(fù)寫,可加final限定 longstart=System.currentTimeMillis();code();//不確定的功能局部,提取出來(lái),通過抽象方法實(shí)現(xiàn) longend=System.currentTimeMillis(); System.out.println("毫秒是:"+(end-start)); }publicabstractvoidcode();//抽象不確定的功能,讓子類復(fù)寫實(shí)現(xiàn)}classSubDemoextendsGetTime{publicvoidcode(){//子類復(fù)寫功能方法 for(inty=0;y<1000;y++){ System.out.println("y"); } }}---------------------------------------------------------------------------------------------接口:★★★★★1:是用關(guān)鍵字interface定義的。2:接口中包含的成員,最常見的有全局常量、抽象方法。注意:接口中的成員都有固定的修飾符。成員變量:publicstaticfinal 成員方法:publicabstractinterfaceInter{publicstaticfinalintx=3;publicabstractvoidshow();}3:接口中有抽象方法,說明接口不可以實(shí)例化。接口的子類必須實(shí)現(xiàn)了接口中所有的抽象方法后,該子類才可以實(shí)例化。否那么,該子類還是一個(gè)抽象類。4:類與類之間存在著繼承關(guān)系,類與接口中間存在的是實(shí)現(xiàn)關(guān)系。繼承用extends;實(shí)現(xiàn)用implements;5:接口和類不一樣的地方,就是,接口可以被多實(shí)現(xiàn),這就是多繼承改良后的結(jié)果。java將多繼承機(jī)制通過多現(xiàn)實(shí)來(lái)表達(dá)。6:一個(gè)類在繼承另一個(gè)類的同時(shí),還可以實(shí)現(xiàn)多個(gè)接口。所以接口的出現(xiàn)防止了單繼承的局限性。還可以將類進(jìn)展功能的擴(kuò)展。7:其實(shí)java中是有多繼承的。接口與接口之間存在著繼承關(guān)系,接口可以多繼承接口。接口都用于設(shè)計(jì)上,設(shè)計(jì)上的特點(diǎn):〔可以理解主板上提供的接口〕1:接口是對(duì)外提供的規(guī)那么。2:接口是功能的擴(kuò)展。3:接口的出現(xiàn)降低了耦合性。抽象類與接口:抽象類:一般用于描述一個(gè)體系單元,將一組共性內(nèi)容進(jìn)展抽取,特點(diǎn):可以在類中定義抽象內(nèi)容讓子類實(shí)現(xiàn),可以定義非抽象內(nèi)容讓子類直接使用。它里面定義的都是一些體系中的基本內(nèi)容。接口:一般用于定義對(duì)象的擴(kuò)展功能,是在繼承之外還需這個(gè)對(duì)象具備的一些功能。抽象類和接口的共性:都是不斷向上抽取的結(jié)果。抽象類和接口的區(qū)別:1:抽象類只能被繼承,而且只能單繼承。接口需要被實(shí)現(xiàn),而且可以多實(shí)現(xiàn)。2:抽象類中可以定義非抽象方法,子類可以直接繼承使用。接口中都有抽象方法,需要子類去實(shí)現(xiàn)。3:抽象類使用的是isa關(guān)系。接口使用的likea關(guān)系。4:抽象類的成員修飾符可以自定義。接口中的成員修飾符是固定的。全都是public的。在開發(fā)之前,先定義規(guī)那么,A和B分別開發(fā),A負(fù)責(zé)實(shí)現(xiàn)這個(gè)規(guī)那么,B負(fù)責(zé)使用這個(gè)規(guī)那么。至于A是如何對(duì)規(guī)那么具體實(shí)現(xiàn)的,B是不需要知道的。這樣這個(gè)接口的出現(xiàn)就降低了A和B直接耦合性。------------------------------------------------------------------------------------------------多態(tài)★★★★★〔面向?qū)ο筇卣髦弧常汉瘮?shù)本身就具備多態(tài)性,某一種事物有不同的具體的表達(dá)。表達(dá):父類引用或者接口的引用指向了自己的子類對(duì)象。//Animala=newCat();多態(tài)的好處:提高了程序的擴(kuò)展性。多態(tài)的弊端:當(dāng)父類引用指向子類對(duì)象時(shí),雖然提高了擴(kuò)展性,但是只能訪問父類中具備的方法,不可以訪問子類中特有的方法。(前期不能使用后期產(chǎn)生的功能,即訪問的局限性)多態(tài)的前提:1:必須要有關(guān)系,比方繼承、或者實(shí)現(xiàn)。 2:通常會(huì)有覆蓋操作。多態(tài)的出現(xiàn)思想上也做著變化:以前是創(chuàng)立對(duì)象并指揮對(duì)象做事情。有了多態(tài)以后,我們可以找到對(duì)象的共性類型,直接操作共性類型做事情即可,這樣可以指揮一批對(duì)象做事情,即通過操作父類或接口實(shí)現(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畢教師();//畢教師對(duì)象被提升為了畢姥爺類型。// x.講課();// x.看電影();//錯(cuò)誤. 畢教師y=(畢教師)x;//將畢姥爺類型強(qiáng)制轉(zhuǎn)換成畢教師類型。 y.看電影();//在多態(tài)中,自始自終都是子類對(duì)象在做著類型的變化。 }}---------------------------------------------------------------如果想用子類對(duì)象的特有方法,如何判斷對(duì)象是哪個(gè)具體的子類類型呢可以可以通過一個(gè)關(guān)鍵字instanceof;//判斷對(duì)象是否實(shí)現(xiàn)了指定的接口或繼承了指定的類格式:<對(duì)象instanceof類型>,判斷一個(gè)對(duì)象是否所屬于指定的類型。StudentinstanceofPerson=true;//student繼承了person類多態(tài)在子父類中的成員上的表達(dá)的特點(diǎn):1,成員變量:在多態(tài)中,子父類成員變量同名。 在編譯時(shí)期:參考的是引用型變量所屬的類中是否有調(diào)用的成員?!簿幾g時(shí)不產(chǎn)生對(duì)象,只檢查語(yǔ)法錯(cuò)誤〕 運(yùn)行時(shí)期:也是參考引用型變量所屬的類中是否有調(diào)用的成員。簡(jiǎn)單一句話:無(wú)論編譯和運(yùn)行,成員變量參考的都是引用變量所屬的類中的成員變量。 再說的更容易記憶一些:成員變量---編譯運(yùn)行都看=左邊。2,成員函數(shù)。 編譯時(shí)期:參考引用型變量所屬的類中是否有調(diào)用的方法。 運(yùn)行事情:參考的是對(duì)象所屬的類中是否有調(diào)用的方法。 為什么是這樣的呢因?yàn)樵谧痈割愔?,?duì)于一模一樣的成員函數(shù),有一個(gè)特性:覆蓋。 簡(jiǎn)單一句:成員函數(shù),編譯看引用型變量所屬的類,運(yùn)行看對(duì)象所屬的類。更簡(jiǎn)單:成員函數(shù)---編譯看=左邊,運(yùn)行看=右邊。3,靜態(tài)函數(shù)。 編譯時(shí)期:參考的是引用型變量所屬的類中是否有調(diào)用的成員。 運(yùn)行時(shí)期:也是參考引用型變量所屬的類中是否有調(diào)用的成員。為什么是這樣的呢因?yàn)殪o態(tài)方法,其實(shí)不所屬于對(duì)象,而是所屬于該方法所在的類。 調(diào)用靜態(tài)的方法引用是哪個(gè)類的引用調(diào)用的就是哪個(gè)類中的靜態(tài)方法。簡(jiǎn)單說:靜態(tài)函數(shù)---編譯運(yùn)行都看=左邊。-----------------------------------------------------------------------------------------------------java.lang.ObjectObject:所有類的直接或者間接父類,Java認(rèn)為所有的對(duì)象都具備一些基本的共性內(nèi)容,這些內(nèi)容可以不斷的向上抽取,最終就抽取到了一個(gè)最頂層的類中的,該類中定義的就是所有對(duì)象都具備的功能。具體方法:1,booleanequals(Objectobj):用于比較兩個(gè)對(duì)象是否相等,其實(shí)內(nèi)部比較的就是兩個(gè)對(duì)象地址。而根據(jù)對(duì)象的屬性不同,判斷對(duì)象是否一樣的具體內(nèi)容也不一樣。所以在定義類時(shí),一般都會(huì)復(fù)寫equals方法,建設(shè)本類特有的判斷對(duì)象是否一樣的依據(jù)。 publicbooleanequals(Objectobj){ if(!(objinstanceofPerson)) returnfalse; Personp=(Person)obj; returnthis.age==p.age; }2,StringtoString():將對(duì)象變成字符串;默認(rèn)返回的格式:類名@哈希值=getClass().getName()+'@'+Integer.toHexString(hashCode()) 為了對(duì)象對(duì)應(yīng)的字符串內(nèi)容有意義,可以通過復(fù)寫,建設(shè)該類對(duì)象自己特有的字符串表現(xiàn)形式。 publicStringtoString(){ return"person:"+age; }3,ClassgetClass():獲取任意對(duì)象運(yùn)行時(shí)的所屬字節(jié)碼文件對(duì)象。4,inthashCode():返回該對(duì)象的哈希碼值。支持此方法是為了提高哈希表的性能。通常equals,toString,hashCode,在應(yīng)用中都會(huì)被復(fù)寫,建設(shè)具體對(duì)象的特有的內(nèi)容。------------------------------------------------------------------------------------------------內(nèi)部類:如果A類需要直接訪問B類中的成員,而B類又需要建設(shè)A類的對(duì)象。這時(shí),為了方便設(shè)計(jì)和訪問,直接將A類定義在B類中。就可以了。A類就稱為內(nèi)部類。內(nèi)部類可以直接訪問外部類中的成員。而外部類想要訪問內(nèi)部類,必須要建設(shè)內(nèi)部類的對(duì)象。-----------------------------------------------------classOuter{ intnum=4; classInner{ voidshow(){ System.out.println("innershowrun"+num); } } publicvoidmethod(){ Innerin=newInner();//創(chuàng)立內(nèi)部類的對(duì)象。 in.show();//調(diào)用內(nèi)部類的方法。 }}-------------------------------------------------------當(dāng)內(nèi)部類定義在外部類中的成員位置上,可以使用一些成員修飾符修飾private、static。1:默認(rèn)修飾符。直接訪問內(nèi)部類格式:外部類名.內(nèi)部類名變量名=外部類對(duì)象.內(nèi)部類對(duì)象;Outer.Innerin=newOuter.newInner();//這種形式很少用。 但是這種應(yīng)用不多見,因?yàn)閮?nèi)部類之所以定義在內(nèi)部就是為了封裝。想要獲取內(nèi)部類對(duì)象通常都通過外部類的方法來(lái)獲取。這樣可以對(duì)內(nèi)部類對(duì)象進(jìn)展控制。2:私有修飾符。 通常內(nèi)部類被封裝,都會(huì)被私有化,因?yàn)榉庋b性不讓其他程序直接訪問。3:靜態(tài)修飾符。如果內(nèi)部類被靜態(tài)修飾,相當(dāng)于外部類,會(huì)出現(xiàn)訪問局限性,只能訪問外部類中的靜態(tài)成員。 注意;如果內(nèi)部類中定義了靜態(tài)成員,那么該內(nèi)部類必須是靜態(tài)的。內(nèi)部類編譯后的文件名為:“外部類名$內(nèi)部類名.java〞;為什么內(nèi)部類可以直接訪問外部類中的成員呢那是因?yàn)閮?nèi)部中都持有一個(gè)外部類的引用。這個(gè)是引用是外部類名.this內(nèi)部類可以定義在外部類中的成員位置上,也可以定義在外部類中的局部位置上。當(dāng)內(nèi)部類被定義在局部位置上,只能訪問局部中被final修飾的局部變量。匿名內(nèi)部類:沒有名字的內(nèi)部類。就是內(nèi)部類的簡(jiǎn)化形式。一般只用一次就可以用這種形式。匿名內(nèi)部類其實(shí)就是一個(gè)匿名子類對(duì)象。想要定義匿名內(nèi)部類:需要前提,內(nèi)部類必須繼承一個(gè)類或者實(shí)現(xiàn)接口。匿名內(nèi)部類的格式:new父類名&接口名(){定義子類成員或者覆蓋父類方法}.方法。匿名內(nèi)部類的使用場(chǎng)景:當(dāng)函數(shù)的參數(shù)是接口類型引用時(shí),如果接口中的方法不超過3個(gè)??梢酝ㄟ^匿名內(nèi)部類來(lái)完成參數(shù)的傳遞。其實(shí)就是在創(chuàng)立匿名內(nèi)部類時(shí),該類中的封裝的方法不要過多,最好兩個(gè)或者兩個(gè)以內(nèi)。--------------------------------------------------------//面試//1 newObject(){ voidshow(){ System.out.println("showrun"); } }.show();//2 Objectobj=newObject(){ voidshow(){ System.out.println("showrun"); } };obj.show(); 1和2的寫法正確嗎有區(qū)別嗎說出原因。 寫法是正確,1和2都是在通過匿名內(nèi)部類建設(shè)一個(gè)Object類的子類對(duì)象。 區(qū)別: 第一個(gè)可是編譯通過,并運(yùn)行。 第二個(gè)編譯失敗,因?yàn)槟涿麅?nèi)部類是一個(gè)子類對(duì)象,當(dāng)用Object的obj引用指向時(shí),就被提升為了 Object類型,而編譯時(shí)檢查Object類中是否有show方法,所以編譯失敗。-------------------------------------------------------classInnerClassDemo6{+〔static〕classInner{ voidshow(){} } publicvoidmethod(){this.newInner().show();//可以 } publicstaticvoidmain(String[]args){//static不允許this This.newInner().show();//錯(cuò)誤,Inner類需要定義成static }}------------------------------------------------------interfaceInter{ voidshow();}classOuter{//通過匿名內(nèi)部類補(bǔ)足Outer類中的代碼。 publicstaticIntermethod(){ returnnewInter(){ publicvoidshow(){} }; }}classInnerClassDemo7{ publicstaticvoidmain(String[]args){Outer.method().show(); /* Outer.method():意思是:Outer中有一個(gè)名稱為method的方法,而且這個(gè)方法是靜態(tài)的。 Outer.method().show():當(dāng)Outer類調(diào)用靜態(tài)的method方法運(yùn)算完畢后的結(jié)果又調(diào)用了show方法,意味著:method()方法運(yùn)算完一個(gè)是對(duì)象,而且這個(gè)對(duì)象是Inter類型的。 */function(newInter(){ publicvoidshow(){} });//匿名內(nèi)部類作為方法的參數(shù)進(jìn)展傳遞。 } publicstaticvoidfunction(Interin){ in.show(); }}------------------------------------------------------------------------------------------------異常:★★★★異常:就是不正常。程序在運(yùn)行時(shí)出現(xiàn)的不正常情況。其實(shí)就是程序中出現(xiàn)的問題。這個(gè)問題按照面向?qū)ο笏枷脒M(jìn)展描述,并封裝成了對(duì)象。因?yàn)閱栴}的產(chǎn)生有產(chǎn)生的原因、有問題的名稱、有問題的描述等多個(gè)屬性信息存在。當(dāng)出現(xiàn)多屬性信息最方便的方式就是將這些信息進(jìn)展封裝。異常就是java按照面向?qū)ο蟮乃枷雽栴}進(jìn)展對(duì)象封裝。這樣就方便于操作問題以及處理問題。出現(xiàn)的問題有很多種,比方角標(biāo)越界,空指針等都是。就對(duì)這些問題進(jìn)展分類。而且這些問題都有共性內(nèi)容比方:每一個(gè)問題都有名稱,同時(shí)還有問題描述的信息,問題出現(xiàn)的位置,所以可以不斷的向上抽取。形成了異常體系。--------java.lang.Throwable:Throwable:可拋出的。|--Error:錯(cuò)誤,一般情況下,不編寫針對(duì)性的代碼進(jìn)展處理,通常是jvm發(fā)生的,需要對(duì)程序進(jìn)展修正。|--Exception:異常,可以有針對(duì)性的處理方式無(wú)論是錯(cuò)誤還是異常,它們都有具體的子類表達(dá)每一個(gè)問題,它們的子類都有一個(gè)共性,就是都以父類名才作為子類的后綴名。這個(gè)體系中的所有類和對(duì)象都具備一個(gè)獨(dú)有的特點(diǎn);就是可拋性??蓲佇缘谋磉_(dá):就是這個(gè)體系中的類和對(duì)象都可以被throws和throw兩個(gè)關(guān)鍵字所操作。------------------------------------------------------classExceptionDemo{ publicstaticvoidmain(String[]args){// byte[]buf=newbyte[1024*1024*700];//java.lang.OutOfMemoryError內(nèi)存溢出錯(cuò)誤 }}------------------------------------------------------在開發(fā)時(shí),如果定義功能時(shí),發(fā)現(xiàn)該功能會(huì)出現(xiàn)一些問題,應(yīng)該將問題在定義功能時(shí)標(biāo)示出來(lái),這樣調(diào)用者就可以在使用這個(gè)功能的時(shí)候,預(yù)先給出處理方式。如何標(biāo)示呢通過throws關(guān)鍵字完成,格式:throws異常類名,異常類名...這樣標(biāo)示后,調(diào)用者,在使用該功能時(shí),就必須要處理,否那么編譯失敗。處理方式有兩種:1、捕捉;2、拋出。對(duì)于捕捉:java有針對(duì)性的語(yǔ)句塊進(jìn)展處理。try{ 需要被檢測(cè)的代碼;}catch(異常類變量名){ 異常處理代碼;}fianlly{ 一定會(huì)執(zhí)行的代碼;}--------------------------------------------------------catch(Exceptione){//e用于接收try檢測(cè)到的異常對(duì)象。 System.out.println("message:"+e.getMessage());//獲取的是異常的信息。 System.out.println("toString:"+e.toString());//獲取的是異常的名字+異常的信息。 e.printStackTrace();//打印異常在堆棧中信息;異常名稱+異常信息+異常的位置。}---------------------------------------------------------異常處理原那么:功能拋出幾個(gè)異常,功能調(diào)用如果進(jìn)展try處理,需要與之對(duì)應(yīng)的catch處理代碼塊,這樣的處理有針對(duì)性,拋幾個(gè)就處理幾個(gè)。特殊情況:try對(duì)應(yīng)多個(gè)catch時(shí),如果有父類的catch語(yǔ)句塊,一定要放在下面。throw和throws關(guān)鍵字的區(qū)別:throw用于拋出異常對(duì)象,后面跟的是異常對(duì)象;throw用在函數(shù)內(nèi)。throws用于拋出異常類,后面跟的異常類名,可以跟多個(gè),用逗號(hào)隔開。throws用在函數(shù)上。通常情況:函數(shù)內(nèi)容如果有throw,拋出異常對(duì)象,并沒有進(jìn)展處理,那么函數(shù)上一定要聲明,否那么編譯失敗。但是也有特殊情況。異常分兩種:1:編譯時(shí)被檢查的異常,只要是Exception及其子類都是編譯時(shí)被檢測(cè)的異常。2:運(yùn)行時(shí)異常,其中Exception有一個(gè)特殊的子類RuntimeException,以及RuntimeException的子類是運(yùn)行異常,也就說這個(gè)異常是編譯時(shí)不被檢查的異常。編譯時(shí)被檢查的異常和運(yùn)行時(shí)異常的區(qū)別:編譯被檢查的異常在函數(shù)內(nèi)被拋出,函數(shù)必須要聲明,否編譯失敗。聲明的原因:是需要調(diào)用者對(duì)該異常進(jìn)展處理。運(yùn)行時(shí)異常如果在函數(shù)內(nèi)被拋出,在函數(shù)上不需要聲明。不聲明的原因:不需要調(diào)用者處理,運(yùn)行時(shí)異常發(fā)生,已經(jīng)無(wú)法再讓程序繼續(xù)運(yùn)行,所以,不讓調(diào)用處理的,直接讓程序停頓,由調(diào)用者對(duì)代碼進(jìn)展修正。定義異常處理時(shí),什么時(shí)候定義try,什么時(shí)候定義throws呢功能內(nèi)部如果出現(xiàn)異常,如果內(nèi)部可以處理,就用try;如果功能內(nèi)部處理不了,就必須聲明出來(lái),讓調(diào)用者處理。自定義異常:當(dāng)開發(fā)時(shí),工程中出現(xiàn)了java中沒有定義過的問題時(shí),這時(shí)就需要我們按照java異常建設(shè)思想,將工程的中的特有問題也進(jìn)展對(duì)象的封裝。這個(gè)異常,稱為自定義異常。對(duì)于除法運(yùn)算,0作為除數(shù)是不可以的。java中對(duì)這種問題用ArithmeticException類進(jìn)展描述。對(duì)于這個(gè)功能,在我們工程中,除數(shù)除了不可以為0外,還不可以為負(fù)數(shù)??墒秦?fù)數(shù)的局部java并沒有針對(duì)描述。所以我們就需要自定義這個(gè)異常。自定義異常的步驟:1:定義一個(gè)子類繼承Exception或RuntimeException,讓該類具備可拋性。2:通過throw或者throws進(jìn)展操作。異常的轉(zhuǎn)換思想:當(dāng)出現(xiàn)的異常是調(diào)用者處理不了的,就需要將此異常轉(zhuǎn)換為一個(gè)調(diào)用者可以處理的異常拋出。trycatchfinally的幾種結(jié)合方式:2,trycatch2,trycatch3,tryfinallytrycatchfinally這種情況,如果出現(xiàn)異常,并不處理,但是資源一定關(guān)閉,所以tryfinally集合只為關(guān)閉資源。記?。篺inally很有用,主要用戶關(guān)閉資源。無(wú)論是否發(fā)生異常,資源都必須進(jìn)展關(guān)閉。System.exit(0);//退出jvm,只有這種情況finally不執(zhí)行。當(dāng)異常出現(xiàn)后,在子父類進(jìn)展覆蓋時(shí),有了一些新的特點(diǎn):1:當(dāng)子類覆蓋父類的方法時(shí),如果父類的方法拋出了異常,那么子類的方法要么不拋出異常要么拋出父類異?;蛘咴摦惓5淖宇悾荒軖伋銎渌惓?。2:如果父類拋出了多個(gè)異常,那么子類在覆蓋時(shí)只能拋出父類的異常的子集。注意:如果父類或者接口中的方法沒有拋出過異常,那么子類是不可以拋出異常的,如果子類的覆蓋的方法中出現(xiàn)了異常,只能try不能throws。如果這個(gè)異常子類無(wú)法處理,已經(jīng)影響了子類方法的具體運(yùn)算,這時(shí)可以在子類方法中,通過throw拋出RuntimeException異常或者其子類,這樣,子類的方法上是不需要throws聲明的。常見異常:1、腳標(biāo)越界異?!睮ndexOutOfBoundsException〕包括數(shù)組、字符串;空指針異?!睳ullPointerException〕2、類型轉(zhuǎn)換異常:ClassCastException3、沒有這個(gè)元素異常:NullPointerException4、不支持操作異常;異常要盡量防止,如果防止不了,需要預(yù)先給出處理方式。比方家庭備藥,比方滅火器。-----------------------------------------------------------------------------------------------包:定義包用package關(guān)鍵字。1:對(duì)類文件進(jìn)展分類管理。2:給類文件提供多層名稱空間。如果生成的包不在當(dāng)前目錄下,需要最好執(zhí)行classpath,將包所在父目錄定義到classpath變量中即可。一般在定義包名時(shí),因?yàn)榘某霈F(xiàn)是為了區(qū)分重名的類。所以包名要盡量唯一。怎么保證唯一性呢可以使用url域名來(lái)進(jìn)展包名稱的定義。packagepack;//定義了一個(gè)包,名稱為pack。注意:包名的寫法標(biāo)準(zhǔn):所有字母都小寫。//packagecn.itcast.pack.demo;類的全名稱是包名.類名編譯命令:javac–d位置〔.當(dāng)前路徑〕java源文件〔就可以自動(dòng)生成包〕包是一種封裝形式,用于封裝類,想要被包以外的程序訪問,該類必須public;類中的成員,如果被包以外訪問,也必須public;包與包之間訪問可以使用的權(quán)限有兩種:1:public2:protected:只能是不同包中的子類可以使用的權(quán)限。總結(jié)java中的四種權(quán)限:范圍public protected default private同一個(gè)類中ok ok ok ok同一包中 ok ok ok 子類 ok 不同包中ok-----------------------------------------------------------------------------------------------Import-導(dǎo)入:類名稱變長(zhǎng),寫起來(lái)很麻煩。為了簡(jiǎn)化,使用了一個(gè)關(guān)鍵字:import,可以使用這個(gè)關(guān)鍵字導(dǎo)入指定包中的類。記?。簩?shí)際開發(fā)時(shí),到的哪個(gè)類就導(dǎo)入哪個(gè)類,不建議使用*.importpacka.*;//這個(gè)僅僅是導(dǎo)入了packa當(dāng)前目錄下的所有的類。不包含子包。importpacka.abc.*;//導(dǎo)入了packa包中的子包abc下的當(dāng)前的所有類。如果導(dǎo)入的兩個(gè)包中存在著一樣名稱的類。這時(shí)如果用到該類,必須在代碼中指定包名。常見的軟件包:java.lang:languagejava的核心包,ObjectSystemStringThrowablejdk1.2版本后,該包中的類自動(dòng)被導(dǎo)入。java.awt:定義的都是用于java圖形界面開發(fā)的對(duì)象。javax.swing:提供所有的windows桌面應(yīng)用程序包括的控件,比方:Frame,Dialog,Table,List等等,就是java的圖形界面庫(kù)。:用于java網(wǎng)絡(luò)編程方面的對(duì)象都在該包中。java.io:inputoutput用于操作設(shè)備上數(shù)據(jù)的對(duì)象都在該包中。比方:讀取硬盤數(shù)據(jù),往硬盤寫入數(shù)據(jù)。java.util:java的工具包,時(shí)間對(duì)象,集合框架。java.applet:application+let客戶端java小程序。server+let-->servlet服務(wù)端java小程序。jar:java的壓縮包,主要用于存儲(chǔ)類文件,或者配置文件等。命令格式:jar–cf包名.jar包目錄解壓縮:jar–xvf包名.jar將jar包目錄列表重定向到一個(gè)文件中:jar–tf包名.jar>c:\1.txt-----------------------------------------------------------------------------------------------多線程:★★★★進(jìn)程:正在進(jìn)展中的程序。其實(shí)進(jìn)程就是一個(gè)應(yīng)用程序運(yùn)行時(shí)的內(nèi)存分配空間。線程:其實(shí)就是進(jìn)程中一個(gè)程序執(zhí)行控制單元,一條執(zhí)行路徑。進(jìn)程負(fù)責(zé)的是應(yīng)用程序的空間的標(biāo)示。線程負(fù)責(zé)的是應(yīng)用程序的執(zhí)行順序。一個(gè)進(jìn)程至少有一個(gè)線程在運(yùn)行,當(dāng)一個(gè)進(jìn)程中出現(xiàn)多個(gè)線程時(shí),就稱這個(gè)應(yīng)用程序是多線程應(yīng)用程序,每個(gè)線程在棧區(qū)中都有自己的執(zhí)行空間,自己的方法區(qū)、自己的變量。jvm在啟動(dòng)的時(shí),首先有一個(gè)主線程,負(fù)責(zé)程序的執(zhí)行,調(diào)用的是main函數(shù)。主線程執(zhí)行的代碼都在main方法中。當(dāng)產(chǎn)生垃圾時(shí),收垃圾的動(dòng)作,是不需要主線程來(lái)完成,因?yàn)檫@樣,會(huì)出現(xiàn)主線程中的代碼執(zhí)行會(huì)停頓,會(huì)去運(yùn)行垃圾回收器代碼,效率較低,所以由單獨(dú)一個(gè)線程來(lái)負(fù)責(zé)垃圾回收。隨機(jī)性的原理:因?yàn)閏pu的快速切換造成,哪個(gè)線程獲取到了cpu的執(zhí)行權(quán),哪個(gè)線程就執(zhí)行。返回當(dāng)前線程的名稱:Thread.currentThread().getName()線程的名稱是由:Thread-編號(hào)定義的。編號(hào)從0開場(chǎng)。線程要運(yùn)行的代碼都統(tǒng)一存放在了run方法中。線程要運(yùn)行必須要通過類中指定的方法開啟。start方法?!矄?dòng)后,就多了一條執(zhí)行路徑〕start方法:1〕、啟動(dòng)了線程;2〕、讓jvm調(diào)用了run方法。創(chuàng)立線程的第一種方式:繼承Thread,由子類復(fù)寫run方法。步驟:1,定義類繼承Thread類;2,目的是復(fù)寫run方法,將要讓線程運(yùn)行的代碼都存儲(chǔ)到run方法中;3,通過創(chuàng)立Thread類的子類對(duì)象,創(chuàng)立線程對(duì)象;4,調(diào)用線程的start方法,開啟線程,并執(zhí)行run方法。線程狀態(tài):被創(chuàng)立:start()運(yùn)行:具備執(zhí)行資格,同時(shí)具備執(zhí)行權(quán);凍結(jié):sleep(time),wait()—notify()喚醒;線程釋放了執(zhí)行權(quán),同時(shí)釋放執(zhí)行資格;臨時(shí)阻塞狀態(tài):線程具備cpu的執(zhí)行資格,沒有cpu的執(zhí)行權(quán);消亡:stop()創(chuàng)立線程的第二種方式:實(shí)現(xiàn)一個(gè)接口Runnable。步驟:1,定義類實(shí)現(xiàn)Runnable接口。2,覆蓋接口中的run方法〔用于封裝線程要運(yùn)行的代碼〕。3,通過Thread類創(chuàng)立線程對(duì)象;4,將實(shí)現(xiàn)了Runnable接口的子類對(duì)象作為實(shí)際參數(shù)傳遞給Thread類中的構(gòu)造函數(shù)。為什么要傳遞呢因?yàn)橐尵€程對(duì)象明確要運(yùn)行的run方法所屬的對(duì)象。5,調(diào)用Thread對(duì)象的start方法。開啟線程,并運(yùn)行Runnable接口子類中的run方法。Tickett=newTicket(); /* 直接創(chuàng)立Ticket對(duì)象,并不是創(chuàng)立線程對(duì)象。 因?yàn)閯?chuàng)立對(duì)象只能通過newThread類,或者newThread類的子類才可以。 所以最終想要?jiǎng)?chuàng)立線程。既然沒有了Thread類的子類,就只能用Thread類。 */Threadt1=newThread(t);//創(chuàng)立線程。 /* 只要將t作為Thread類的構(gòu)造函數(shù)的實(shí)際參數(shù)傳入即可完成線程對(duì)象和t之間的關(guān)聯(lián) 為什么要將t傳給Thread類的構(gòu)造函數(shù)呢其實(shí)就是為了明確線程要運(yùn)行的代碼run方法。 */t1.start();為什么要有Runnable接口的出現(xiàn)1:通過繼承Thread類的方式,可以完成多線程的建設(shè)。但是這種方式有一個(gè)局限性,如果一個(gè)類已經(jīng)有了自己的父類,就不可以繼承Thread類,因?yàn)閖ava單繼承的局限性。可是該類中的還有局部代碼需要被多個(gè)線程同時(shí)執(zhí)行。這時(shí)怎么辦呢只有對(duì)該類進(jìn)展額外的功能擴(kuò)展,java就提供了一個(gè)接口Runnable。這個(gè)接口中定義了run方法,其實(shí)run方法的定義就是為了存儲(chǔ)多線程要運(yùn)行的代碼。所以,通常創(chuàng)立線程都用第二種方式。因?yàn)閷?shí)現(xiàn)Runnable接口可以防止單繼承的局限性。2:其實(shí)是將不同類中需要被多線程執(zhí)行的代碼進(jìn)展抽取。將多線程要運(yùn)行的代碼的位置單獨(dú)定義到接口中。為其他類進(jìn)展功能擴(kuò)展提供了前提。所以Thread類在描述線程時(shí),內(nèi)部定義的run方法,也來(lái)自于Runnable接口。實(shí)現(xiàn)Runnable接口可以防止單繼承的局限性。而且,繼承Thread,是可以對(duì)Thread類中的方法,進(jìn)展子類復(fù)寫的。但是不需要做這個(gè)復(fù)寫動(dòng)作的話,只為定義線程代碼存放位置,實(shí)現(xiàn)Runnable接口更方便一些。所以Runnable接口將線程要執(zhí)行的任務(wù)封裝成了對(duì)象。-------------------------------------------------------//面試 newThread(newRunnable(){//匿名 publicvoidrun(){ System.out.println("runnablerun"); } }) { publicvoidrun(){ System.out.println("subthreadrun"); } }.start();//結(jié)果:subthreadrun---------------------------------------------------------Try{Thread.sleep(10);}catch(InterruptedExceptione){}//當(dāng)刻意讓線程稍微停一下,模擬cpu 切換情況。多線程安全問題的原因:通過圖解:發(fā)現(xiàn)一個(gè)線程在執(zhí)行多條語(yǔ)句時(shí),并運(yùn)算同一個(gè)數(shù)據(jù)時(shí),在執(zhí)行過程中,其他線程參與進(jìn)來(lái),并操作了這個(gè)數(shù)據(jù)。導(dǎo)致到了錯(cuò)誤數(shù)據(jù)的產(chǎn)生。涉及到兩個(gè)因素:1,多個(gè)線程在操作共享數(shù)據(jù)。2,有多條語(yǔ)句對(duì)共享數(shù)據(jù)進(jìn)展運(yùn)算。原因:這多條語(yǔ)句,在某一個(gè)時(shí)刻被一個(gè)線程執(zhí)行時(shí),還沒有執(zhí)行完,就被其他線程執(zhí)行了。解決安全問題的原理:只要將操作共享數(shù)據(jù)的語(yǔ)句在某一時(shí)段讓一個(gè)線程執(zhí)行完,在執(zhí)行過程中,其他線程不能進(jìn)來(lái)執(zhí)行就可以解決這個(gè)問題。如何進(jìn)展多句操作共享數(shù)據(jù)代碼的封裝呢java中提供了一個(gè)解決方式:就是同步代碼塊。格式:synchronized(對(duì)象){//任意對(duì)象都可以。這個(gè)對(duì)象就是鎖。 需要被同步的代碼;}---------------------------------------------------------------同步:★★★★★好處:解決了線程安全問題。弊端:相對(duì)降低性能,因?yàn)榕袛噫i需要消耗資源,產(chǎn)生了死鎖。定義同步是有前提的:1,必須要有兩個(gè)或者兩個(gè)以上的線程,才需要同步。2,多個(gè)線程必須保證使用的是同一個(gè)鎖。同步的第二種表現(xiàn)形式:同步函數(shù):其實(shí)就是將同步關(guān)鍵字定義在函數(shù)上,讓函數(shù)具備了同步性。同步函數(shù)是用的哪個(gè)鎖呢通過驗(yàn)證,函數(shù)都有自己所屬的對(duì)象this,所以同步函數(shù)所使用的鎖就是this鎖。當(dāng)同步函數(shù)被static修飾時(shí),這時(shí)的同步用的是哪個(gè)鎖呢靜態(tài)函數(shù)在加載時(shí)所屬于類,這時(shí)有可能還沒有該類產(chǎn)生的對(duì)象,但是該類的字節(jié)碼文件加載進(jìn)內(nèi)存就已經(jīng)被封裝成了對(duì)象,這個(gè)對(duì)象就是該類的字節(jié)碼文件對(duì)象。所以靜態(tài)加載時(shí),只有一個(gè)對(duì)象存在,那么靜態(tài)同步函數(shù)就使用的這個(gè)對(duì)象。這個(gè)對(duì)象就是類名.class同步代碼塊和同步函數(shù)的區(qū)別同步代碼塊使用的鎖可以是任意對(duì)象。同步函數(shù)使用的鎖是this,靜態(tài)同步函數(shù)的鎖是該類的字節(jié)碼文件對(duì)象。在一個(gè)類中只有一個(gè)同步,可以使用同步函數(shù)。如果有多同步,必須使用同步代碼塊,來(lái)確定不同的鎖。所以同步代碼塊相對(duì)靈活一些。-------------------------------------------------------★考點(diǎn)問題:請(qǐng)寫一個(gè)延遲加載的單例模式寫懶漢式;當(dāng)出現(xiàn)多線程訪問時(shí)怎么解決加同步,解決安全問題;效率高嗎不高;怎樣解決通過雙重判斷的形式解決。//懶漢式:延遲加載方式。當(dāng)多線程訪問懶漢式時(shí),因?yàn)閼袧h式的方法內(nèi)對(duì)共性數(shù)據(jù)進(jìn)展多

溫馨提示

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

最新文檔

評(píng)論

0/150

提交評(píng)論