java 基礎(chǔ)

java 兩大核心機(jī)制

? (1) JVM(Java Virtual Machine),java 虛擬機(jī)

JVM 是一個(gè)虛擬的計(jì)算機(jī),具有指令集并使用不同的存儲(chǔ)區(qū)域。負(fù)責(zé)執(zhí)行指令,管理數(shù)據(jù),內(nèi)存,寄存器。

java 的一次編譯,到處運(yùn)行。就是依據(jù)java 虛擬機(jī)機(jī)制屏蔽了底層運(yùn)行平臺(tái)的差別。

? (1) GC(Garbage Collection),垃圾收集

一、封裝

? 使用者直接對(duì)類內(nèi)部的屬性進(jìn)行操作會(huì)導(dǎo)致數(shù)據(jù)的錯(cuò)誤、混亂或安全性問(wèn)題??梢酝ㄟ^(guò)聲明為private ,再提供get/set 方法進(jìn)行訪問(wèn)。

二、重載

? 在一個(gè)類中允許同時(shí)存在一個(gè)以上同名函數(shù),只要參數(shù)個(gè)數(shù),參數(shù)類型 不同即可。

三、this 關(guān)鍵詞

? 是當(dāng)前類的一個(gè)對(duì)象的引用。

四、類的繼承(extends)

? 子類繼承了父類,就繼承了父類中非私有的屬性和方法。子類中可以使用父類的屬性和方法,也可以創(chuàng)建新的數(shù)據(jù)和方法。

? java 只支持單繼承,不允許多繼承。

? ? -- 一個(gè)子類只能有一個(gè)父類。

? ? -- 一個(gè)父類可以派生出多個(gè)子類。

? ? -- 子類不能繼承父類的構(gòu)造方法。

五、訪問(wèn)控制


六、重寫

? 子類可以根據(jù)需要對(duì)從父類繼承來(lái)的方法進(jìn)行改造(方法的重置/重寫),在程序執(zhí)行時(shí),子類的方法將覆蓋父類的方法。

? 覆蓋的方法必須和被覆蓋方法具有相同的方法名、參數(shù)列表和返回值。

? 覆蓋方法不能使用比被覆蓋方法更嚴(yán)格的訪問(wèn)權(quán)限。

七、super 關(guān)鍵字

? 是在子類中對(duì)父類的引用。

? 子類的構(gòu)造器必須調(diào)用父類的一個(gè)構(gòu)造器。不顯示調(diào)用,則默認(rèn)調(diào)用父類無(wú)參的構(gòu)造器。

? super 和 this 不能同時(shí)在一個(gè)構(gòu)造函數(shù)中出現(xiàn)。

? super 和 this 只能作為構(gòu)造函數(shù)的第一行出現(xiàn)。

八、多態(tài)

? 同樣類型的變量,調(diào)用同樣的方法,卻產(chǎn)生完全不同的行為。

? 父類指向子類的引用(父類 = new 子類)。父類調(diào)用方法,調(diào)用的將是子類重寫的方法。

? ? 例子:

? ? ? Person p1 = new Man();

? ? ? p1.walk(); // 調(diào)用的是子類重寫的方法。

父類多態(tài)的情況下(父類指向子類的引用(父類 = new 子類)),父類不能調(diào)用父類沒(méi)有的方法??梢酝ㄟ^(guò)強(qiáng)制類型轉(zhuǎn)換的方式解決此問(wèn)題。

? ? 例子:

? ? ? Person p1 = new Man();

? ? ? Man man = (Man) p1;

? 父類的對(duì)象可以轉(zhuǎn)換為任何子類的類型,但有可能會(huì)發(fā)生 類型轉(zhuǎn)換異常。

? 只能在有父子類關(guān)系的情況下才能強(qiáng)制類型轉(zhuǎn)換。

九、instanceof 操作符

? X instanceof A :檢驗(yàn)X 是否為類A 的對(duì)象,返回值為boolean 型。

? 要求X 所屬的類與類A 必須是父子類關(guān)系。否則編譯錯(cuò)誤。

十、static 關(guān)鍵字

? static{} 靜態(tài)代碼塊在類加載時(shí)執(zhí)行,并且只執(zhí)行一次。

十一、單子(singleton)設(shè)計(jì)模式

? 采取一定的方法保證在整個(gè)軟件系統(tǒng)中,對(duì)某個(gè)類智能存在一個(gè)對(duì)象實(shí)例。并且該類只提供了一個(gè)取得其對(duì)象實(shí)例的方法。

? 構(gòu)造器私有化。

? 在該類內(nèi)部提供一個(gè)私有的靜態(tài)實(shí)例對(duì)象。

? 提供一個(gè)get?方法?供外部使用。

? 例子:

? ? private?JavaTest()?{}

????private?static?JavaTest?javaTest?=?new?JavaTest();

????public?static?JavaTest?getJavaTest()?{

????????return?javaTest;

????}

十二、final 關(guān)鍵字

? final 可以修飾類,屬性和方法。表示最終的。

? final 修飾的屬性,是最終的屬性 - 屬性值不能被修改,即常量。

? ? 屬性必須在初始化,或在非靜態(tài)代碼塊,或在構(gòu)造器中進(jìn)行初始化。

? final 修飾的方法,是最終的方法 - 該方法不能被修改 - 該方法不能被重寫。

? final 修飾的類,是最終的類 - 該類不能被擴(kuò)展 - 該類不能被繼承。

十三、抽象類(abstract)

? 用于修飾方法 和 類。

? abstract 修飾的方法: 沒(méi)有方法體,只有方法聲明。

? abstract 修飾的類 : 抽象類,不能被實(shí)例化。抽象類是用來(lái)被繼承的,抽象類的子類必須重寫父類的抽象方法,并提供方法體。

? 有抽象方法的類一定是抽象類,但抽象類中可以沒(méi)有抽象方法。

? 不能用abstract 修飾私有方法,構(gòu)造方法,靜態(tài)方法。

十四、接口(interface)

? 接口是抽象方法和常量的定義集合。

? 接口是一種特殊的抽象類,接口中只能包含常量和方法的定義,而沒(méi)有變量和方法的實(shí)現(xiàn)。

? 接口中所有的成員變量默認(rèn)由public static final 修飾。

? 接口中所有的方法都默認(rèn)由public abstract 修飾。接口中沒(méi)有構(gòu)造方法。

? 實(shí)現(xiàn)接口的類必須提供接口中所有方法的具體實(shí)現(xiàn)。

? 接口允許多實(shí)現(xiàn)。一個(gè)類可以實(shí)現(xiàn)多個(gè)接口。

? 接口與實(shí)現(xiàn)類之間存在多態(tài)性。

? 接口可以繼承另一個(gè)接口。

十五、內(nèi)部類

? 在類的內(nèi)部定義的一個(gè)類。相當(dāng)于一個(gè)類的內(nèi)部成員。

? 在類的外部可以訪問(wèn)該類的內(nèi)部類。

? 靜態(tài)內(nèi)部類中的方法不能訪問(wèn)外部類的非靜態(tài)對(duì)象。

十六、異常

? java 中,將程序執(zhí)行中發(fā)生的不正常情況稱為“異?!薄?/p>

? java 中的異常用于處理非預(yù)期的情況,如文件沒(méi)找到,網(wǎng)絡(luò)錯(cuò)誤,非法參數(shù)等。

? java 程序運(yùn)行過(guò)程中所發(fā)生的異常事件可分為兩類:

? ? Error : JVM 系統(tǒng)內(nèi)部錯(cuò)誤、資源耗盡等嚴(yán)重情況。

? ? Exception : 其他因編程錯(cuò)誤或偶然的外在因素導(dǎo)致的一般問(wèn)題。如空指針訪問(wèn),試圖讀取不存在的文件,網(wǎng)絡(luò)連接中斷。

? 自定義異常:

? ? public??class?JavaTest?extends?RuntimeException?{

? ? ? public?JavaTest()?{

? ? ? }

? ? ? public?JavaTest(String?msg)?{

? ? ? ? ? super(msg);

? ? ? }

? ? }

十七、集合

? java 集合可以分為Set 、List 、Map 三種體系。

? ? -- Set : 無(wú)序,不可重復(fù)的集合。

? ? -- List : 有序,可重復(fù)的集合。

? ? -- Map : 具有映射關(guān)系的集合。

? 1. Collection 接口

? ? Collection 接口是 List ,Set 和 Queue 接口的父接口。該接口里定義的方法即可用于操作Set 集合,也可用于操作List和Queue 集合。

? ? Collection 中無(wú)法獲取指定元素,但可以遍歷所有元素。

? 2. Set 集合

? ? Set 集合不允許包含相同的元素,Set 判斷兩個(gè)對(duì)象是否相同不用==運(yùn)算符,而是根據(jù)equals 方法。

? ? (1) HashSet 是Set 接口的典型實(shí)現(xiàn),大多時(shí)候使用Set 集合時(shí)都使用這個(gè)實(shí)現(xiàn)類。

? ? ? HashSet 按照Hash 算法來(lái)存儲(chǔ)集合中的元素,因此具有很好的存儲(chǔ)和查找功能。

? ? ? HashSet 具有以下特點(diǎn):

? ? ? ? -- 不能保證元素的排列順序。

? ? ? ? -- HashSet 不是線程安全的。

? ? ? ? -- 集合元素可以使用 null 。

? ? (2) LinkedHashSet 是HashSet 的子類。

? ? ? LinkedHashSet 集合根據(jù)元素的hashCode 值來(lái)確定元素的存儲(chǔ)位置。但它同時(shí)使用鏈表維護(hù)元素的次序,這使得元素看起來(lái)是以插入順序保存的。

? ? ? LinkedHashSet 性能插入性能略低于HashSet ,但在迭代訪問(wèn)Set 里全部元素時(shí)有很好的性能。

? ? ? LinkedHashSet 不允許集合元素重復(fù)。

? ? (3) TreeSet

? ? ? Ⅰ. TreeSet?是SortedSet?接口的實(shí)現(xiàn)類,TreeSet?可以確保集合元素處于排序狀態(tài)。

? ? ? ? 默認(rèn)情況下?TreeSet?要求集合中的元素必須實(shí)現(xiàn)Comparable?接口。

? ? ? ? Comparable?中只有一個(gè)方法?:?public?int?compareTo(Object?o)

? ? ? ? ? 若返回0?代表兩個(gè)元素相等;?若返回整數(shù),則代表當(dāng)前元素大;?若返回負(fù)數(shù),則代表當(dāng)前元素小。

? ? ? ? TreeSet?用?Iterator?遍歷。

? ? ? ? Iterator?it?=?set.iterator();

? ? ? ? for(;it.hasNext();){

? ? ? ? ?System.out.println(it.next());

? ? ? ? }

Ⅱ.TreeSet?支持兩種排序方法:自然排序?和?定制排序。默認(rèn)情況下,TreeSet?采用自然排序。

? ? ? ? 自然排序:

? ? ? ? ? 因?yàn)橹挥邢嗤惖膬蓚€(gè)實(shí)例才會(huì)比較大小,所以向TreeSet 中添加的應(yīng)該是一個(gè)類的對(duì)象。

? ? ? ? ? 當(dāng)需要把一個(gè)對(duì)象放入到TreeSet 中,重寫該對(duì)象的equals 方法時(shí),應(yīng)保證該方法與compareTo(Object obj)方法有一致的結(jié)果:如果兩個(gè)對(duì)象通過(guò)equals() 方法比較返回true,則通過(guò)compareTo(Object obj) 方法比較應(yīng)返回 0 。

? ? ? ??定制排序:

傳入的對(duì)象不用實(shí)現(xiàn)Comparable 接口,但是在創(chuàng)建TreeSet 時(shí)需要傳入一個(gè)Comparable 的實(shí)現(xiàn)類。使實(shí)體類更簡(jiǎn)潔。

? ? ? ? ? ? TreeSet set = new TreeSet(new?Comparable?(){ });

? 3. List

? ? List 代表一個(gè)元素有序,且重復(fù)的集合,集合中的每個(gè)元素都有其對(duì)應(yīng)的順序索引。

? ? List 允許使用重復(fù)的元素,可以通過(guò)索引來(lái)訪問(wèn)指定位置的集合元素。

? ? List 默認(rèn)按元素的添加順序設(shè)置元素的索引。

? ? List 集合里添加了一些根據(jù)索引來(lái)操作幾個(gè)元素的方法。

? ? List 額外提供了一個(gè) listlterator() 方法,該方法返回一個(gè)Listlterator 對(duì)象,ListIterator 接口繼承了Iterator 接口,提供了專門操作List 的方法:

? ? Ⅰ. ArrayList 和 Vector?

? ? ? ArrayList 和 Vector 是List 接口的兩個(gè)典型實(shí)現(xiàn)。

? ? ? 區(qū)別:

? ? ? ? 1. 是一個(gè)古老的集合,通常建議使用ArrayList 。

? ? ? ? 2. ArrayList 是線程不安全的,而Vector 是線程安全的。

? ? ? ? 3. 即使為保證List 集合線程安全,也不推薦使用Vector 。

? ? ? Arrays.asList(...) 方法返回的List 集合既不是ArrayList 實(shí)例,也不是Vector 實(shí)例。Arrays.asList(...) 返回值是一個(gè)固定長(zhǎng)度的List 集合。

? 4. Map

? ? Map 用于保存具有映射關(guān)系的數(shù)據(jù),因此Map 集合里保存著兩組值,一組用于保存Map 里的Key ,另外一組用于保存Map 里的Value。

? ? Map 中的key 和 value 都可以是任何引用類型的數(shù)據(jù)。

? ? Map 中的Key 不允許重復(fù),即同一個(gè)Map 對(duì)象的任何兩個(gè)Key 通過(guò)equals 方法比較都返回false 。

? ? key 和 Value 之間存在單向一對(duì)一關(guān)系,即通過(guò)指定的Key 總能找到唯一的,確定的Value 。

? 5. HashMap 和 HashTable

? ? HashMap 和 Hashtable 是Map 接口的兩個(gè)典型實(shí)現(xiàn)類。

? ? 區(qū)別:

? ? ? HashTable 是一個(gè)古老的Map 實(shí)現(xiàn)類,不建議使用。

? ? ? HashTable 是一個(gè)線程安全的Map 實(shí)現(xiàn),但HashMap 是線程不安全的。

? ? ? HashTable 不允許使用null 作為key 和 value ,而HashMap 可以。

? ? 與HashSet 集合不能保證元素的順序一樣,HashTable、HashMap 也不能保存其中key-value 的順序。

? ? HashTable 、HashMap 判斷兩個(gè)key 相等的標(biāo)準(zhǔn)是:兩個(gè)key 通過(guò)equals 方法返回true,HashCode 值也相等。

? ? HashTable 、HashMap 判斷兩個(gè)Value 相等的標(biāo)準(zhǔn)是:兩個(gè)Value 通過(guò)equals 方法返回true 。

? 6. LinkedHashMap?

? ? LinkedHashMap 是HashMap 的子類。

? ? LinkedHashMap 可以維護(hù)Map 的迭代順序:迭代順序與key-value 對(duì)的插入順序一致。

? 7.TreeMap

? ? TreeMap 存儲(chǔ)key-value 時(shí),需要根據(jù)key 對(duì)key-value 進(jìn)行排序。TreeMap 可以保證所有的key-value 處于有序順序。

? ? TreeMap 的Key 排序:

? ? ? 自然排序:TreeMap 的所有key必須實(shí)現(xiàn)Comparable 接口,而且所有的key 應(yīng)該是同一個(gè)類的對(duì)象,否則將會(huì)拋出ClassCastException 。

? ? ? 定制排序:創(chuàng)建TreeMap 時(shí),傳入一個(gè)Comparator 對(duì)象,該對(duì)象負(fù)責(zé)對(duì)TreeMap 中的所有key 進(jìn)行排序。此時(shí)不需要Map 的Key 實(shí)現(xiàn)Comparable 接口。

? 8. Properties

? ? Properties 類是HashTable 的子類,該對(duì)象用于處理屬性文件。

? ? 由于屬性文件里的key 、value 都是字符串類型,所以properties 里的key 和 value 都是字符串類型的。

? ? Properties pro = new Properties();

InputStream in = this.class.getClassLoader().getResourceAsStream("jdbc.properties"); // 通過(guò)類加載器獲得jdbc文件的輸入流

? ? pro.load(in);

? ? String user = pro.getProperties("user");

? 9. Collections 工具類

? ? Collections 是一個(gè)操作Set 、List 和 Map 等集合的工具類。

? ? Collections 中提供了大量方法對(duì)集合元素進(jìn)行排序、查詢和修改等操作,還提供了對(duì)集合對(duì)象設(shè)置不可變燉對(duì)集合對(duì)象實(shí)現(xiàn)同步控制等方法。

? ? 排序操作:

? 10. Enumeration?

? ? Enumeration 接口是Iterator 迭代器的“古老版本”。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 一:java概述: 1,JDK:Java Development Kit,java的開(kāi)發(fā)和運(yùn)行環(huán)境,java的開(kāi)發(fā)...
    慕容小偉閱讀 1,946評(píng)論 0 10
  • 一:java概述:1,JDK:Java Development Kit,java的開(kāi)發(fā)和運(yùn)行環(huán)境,java的開(kāi)發(fā)工...
    ZaneInTheSun閱讀 2,813評(píng)論 0 11
  • 前言:最近感冒的不太想去面試,在家就對(duì)Java se的基礎(chǔ)做了一些小總結(jié) 1.JDK和JRE的區(qū)別 一 基礎(chǔ)知識(shí) ...
    AntCode閱讀 1,208評(píng)論 0 1
  • 在經(jīng)過(guò)一次沒(méi)有準(zhǔn)備的面試后,發(fā)現(xiàn)自己雖然寫了兩年的android代碼,基礎(chǔ)知識(shí)卻忘的差不多了。這是程序員的大忌,沒(méi)...
    猿來(lái)如癡閱讀 3,122評(píng)論 3 10
  • “我的男朋友出軌了,我該怎么辦?” 一個(gè)很久沒(méi)聯(lián)系的姐們打來(lái)電話,一把鼻涕一把淚地向我提出了這個(gè)問(wèn)題。電話那頭,她...
    晏耀飛閱讀 3,327評(píng)論 9 23

友情鏈接更多精彩內(nèi)容