“面试不败计划”:集合、日期、异常、序列化、其他知识点
點擊上方“好好學java”,選擇“置頂公眾號”
優秀學習資源、干貨第一時間送達!
好好學java
java知識分享/學習資源免費分享
關注
?精彩內容?
java實戰練習項目教程
全網最全電子圖書分享
你所需要的大數據視頻教程
java全套學習視頻教程及源碼
關于集合
思考題:1、Java中的集合及其繼承關系
思考題:希望大家積極的思考,并且可以踴躍的說出自己的想法,想法不管對與錯,只要說出來就是一種提高,所以,希望小伙伴們可以把自己的想法在留言區給出,這樣大家也可以相互學習,有啟發的作用,擴展知識面,提高面試能力~
思考題的解答將會在第二天給出!
這里寫圖片描述2、poll()方法和remove()方法區別?
poll() 和 remove() 都是從隊列中取出一個元素,但是 poll() 在獲取元素失敗的時候會返回空,但是 remove() 失敗的時候會拋出異常。
3、LinkedHashMap和PriorityQueue的區別
PriorityQueue 是一個優先級隊列,保證最高或者最低優先級的的元素總是在隊列頭部,但是 LinkedHashMap 維持的順序是元素插入的順序。當遍歷一個 PriorityQueue 時,沒有任何順序保證,但是 LinkedHashMap 課保證遍歷順序是元素插入的順序。
4、WeakHashMap與HashMap的區別是什么?
WeakHashMap 的工作與正常的 HashMap 類似,但是使用弱引用作為 key,意思就是當 key 對象沒有任何引用時,key/value 將會被回收。
5、ArrayList和LinkedList的區別?
最明顯的區別是 ArrrayList底層的數據結構是數組,支持隨機訪問,而 LinkedList 的底層數據結構是雙向循環鏈表,不支持隨機訪問。使用下標訪問一個元素,ArrayList 的時間復雜度是 O(1),而 LinkedList 是 O(n)。
6、ArrayList和Array有什么區別?
Array可以容納基本類型和對象,而ArrayList只能容納對象。
Array是指定大小的,而ArrayList大小是固定的
7、ArrayList和HashMap默認大小?
在 Java 7 中,ArrayList 的默認大小是 10 個元素,HashMap 的默認大小是16個元素(必須是2的冪)。這就是 Java 7 中 ArrayList 和 HashMap 類的代碼片段
private?static?final?int?DEFAULT_CAPACITY?=?10;//from?HashMap.java?JDK?7 static?final?int?DEFAULT_INITIAL_CAPACITY?=?1?<<?4;?//?aka?168、Comparator和Comparable的區別?
Comparable 接口用于定義對象的自然順序,而 comparator 通常用于定義用戶定制的順序。Comparable 總是只有一個,但是可以有多個 comparator 來定義對象的順序。
9、如何實現集合排序?
你可以使用有序集合,如 TreeSet 或 TreeMap,你也可以使用有順序的的集合,如 list,然后通過 Collections.sort() 來排序。
10、如何打印數組內容
你可以使用 Arrays.toString() 和 Arrays.deepToString() 方法來打印數組。由于數組沒有實現 toString() 方法,所以如果將數組傳遞給 System.out.println() 方法,將無法打印出數組的內容,但是 Arrays.toString() 可以打印每個元素。
11、LinkedList的是單向鏈表還是雙向?
雙向循環列表,具體實現自行查閱源碼.
12、TreeMap是實現原理
采用紅黑樹實現,具體實現自行查閱源碼.
13、遍歷ArrayList時如何正確移除一個元素
該問題的關鍵在于面試者使用的是 ArrayList 的 remove() 還是 Iterator 的 remove()方法。這有一段示例代碼,是使用正確的方式來實現在遍歷的過程中移除元素,而不會出現 ConcurrentModificationException 異常的示例代碼。
14、什么是ArrayMap?它和HashMap有什么區別?
ArrayMap是Android SDK中提供的,非Android開發者可以略過.
ArrayMap是用兩個數組來模擬map,更少的內存占用空間,更高的效率.
具體參考這篇文章:ArrayMap VS HashMap:http://lvable.com/?p=217%5D
15、HashMap的實現原理
1 HashMap概述: HashMap是基于哈希表的Map接口的非同步實現。此實現提供所有可選的映射操作,并允許使用null值和null鍵。此類不保證映射的順序,特別是它不保證該順序恒久不變。
2 HashMap的數據結構: 在java編程語言中,最基本的結構就是兩種,一個是數組,另外一個是模擬指針(引用),所有的數據結構都可以用這兩個基本結構來構造的,HashMap也不例外。HashMap實際上是一個“鏈表散列”的數據結構,即數組和鏈表的結合體。
當我們往Hashmap中put元素時,首先根據key的hashcode重新計算hash值,根絕hash值得到這個元素在數組中的位置(下標),如果該數組在該位置上已經存放了其他元素,那么在這個位置上的元素將以鏈表的形式存放,新加入的放在鏈頭,最先加入的放入鏈尾.如果數組中該位置沒有元素,就直接將該元素放到數組的該位置上.
需要注意Jdk 1.8中對HashMap的實現做了優化,當鏈表中的節點數據超過八個之后,該鏈表會轉為紅黑樹來提高查詢效率,從原來的O(n)到O(logn)
16、你了解Fail-Fast機制嗎
Fail-Fast即我們常說的快速失敗,
更多內容參看fail-fast機制:http://blog.csdn.net/chenssy/article/details/38151189
17、Fail-fast和Fail-safe有什么區別
Iterator的fail-fast屬性與當前的集合共同起作用,因此它不會受到集合中任何改動的影響。Java.util包中的所有集合類都被設計為fail->fast的,而java.util.concurrent中的集合類都為fail-safe的。當檢測到正在遍歷的集合的結構被改變時,Fail-fast迭代器拋出ConcurrentModificationException,而fail-safe迭代器從不拋出ConcurrentModificationException。
關于日期
1、SimpleDateFormat是線程安全的嗎?
非常不幸,DateFormat 的所有實現,包括 SimpleDateFormat 都不是線程安全的,因此你不應該在多線程序中使用,除非是在對外線程安全的環境中使用,如 將 SimpleDateFormat 限制在 ThreadLocal 中。如果你不這么做,在解析或者格式化日期的時候,可能會獲取到一個不正確的結果。因此,從日期、時間處理的所有實踐來說,我強力推薦 joda-time 庫。
2、如何格式化日期?
Java 中,可以使用 SimpleDateFormat 類或者 joda-time 庫來格式日期。DateFormat 類允許你使用多種流行的格式來格式化日期。參見答案中的示例代碼,代碼中演示了將日期格式化成不同的格式,如 dd-MM-yyyy 或 ddMMyyyy。
關于異常
1、簡單描述java異常體系
相比沒有人不了解異常體系,關于異常體系的更多信息可以見
2、throw和throws的區別
throw用于主動拋出java.lang.Throwable 類的一個實例化對象,意思是說你可以通過關鍵字 throw 拋出一個 Error 或者 一個Exception,如:throw new IllegalArgumentException(“size must be multiple of 2″),
而throws 的作用是作為方法聲明和簽名的一部分,方法被拋出相應的異常以便調用者能處理。Java 中,任何未處理的受檢查異常強制在 throws 子句中聲明。
關于序列化
1、Java 中,Serializable 與 Externalizable 的區別
Serializable 接口是一個序列化 Java 類的接口,以便于它們可以在網絡上傳輸或者可以將它們的狀態保存在磁盤上,是 JVM 內嵌的默認序列化方式,成本高、脆弱而且不安全。Externalizable 允許你控制整個序列化過程,指定特定的二進制格式,增加安全機制。
其他知識點
1、XML解析的幾種方式和特點
DOM,SAX,PULL三種解析方式:
DOM:消耗內存:先把xml文檔都讀到內存中,然后再用DOM API來訪問樹形結構,并獲取數據。這個寫起來很簡單,但是很消耗內存。要是數據過大,手機不夠牛逼,可能手機直接死機
SAX:解析效率高,占用內存少,基于事件驅動的:更加簡單地說就是對文檔進行順序掃描,當掃描到文檔(document)開始與結束、元素(element)開始與結束、文檔(document)結束等地方時通知事件處理函數,由事件處理函數做相應動作,然后繼續同樣的掃描,直至文檔結束。
PULL:與 SAX 類似,也是基于事件驅動,我們可以調用它的next()方法,來獲取下一個解析事件(就是開始文檔,結束文檔,開始標簽,結束標簽),當處于某個元素時可以調用XmlPullParser的getAttributte()方法來獲取屬性的值,也可調用它的nextText()獲取本節點的值。
3、JDK 1.7特性
然 JDK 1.7 不像 JDK 5 和 8 一樣的大版本,但是,還是有很多新的特性,如 try-with-resource 語句,這樣你在使用流或者資源的時候,就不需要手動關閉,Java 會自動關閉。Fork-Join 池某種程度上實現 Java 版的 Map-reduce。允許 Switch 中有 String 變量和文本。菱形操作符(\<>)用于類型推斷,不再需要在變量聲明的右邊申明泛型,因此可以寫出可讀寫更強、更簡潔的代碼
4、JDK 1.8特性
java 8 在 Java 歷史上是一個開創新的版本,下面 JDK 8 中 5 個主要的特性:
Lambda 表達式,允許像對象一樣傳遞匿名函數
Stream API,充分利用現代多核 CPU,可以寫出很簡潔的代碼
Date 與 Time API,最終,有一個穩定、簡單的日期和時間庫可供你使用
擴展方法,現在,接口中可以有靜態、默認方法。
重復注解,現在你可以將相同的注解在同一類型上使用多次。
5、Maven和ANT有什么區別?
雖然兩者都是構建工具,都用于創建 Java 應用,但是 Maven 做的事情更多,在基于“約定優于配置”的概念下,提供標準的Java 項目結構,同時能為應用自動管理依賴(應用中所依賴的 JAR 文件.
6、JDBC最佳實踐
優先使用批量操作來插入和更新數據
使用PreparedStatement來避免SQL漏洞
使用數據連接池
通過列名來獲取結果集
8、IO操作最佳實踐
使用有緩沖的IO類,不要單獨讀取字節或字符
使用NIO和NIO 2或者AIO,而非BIO
在finally中關閉流
使用內存映射文件獲取更快的IO
往期推薦
“365算法每日學計劃”:05打卡-圖解冒泡排序(多解法)
并發基礎篇(四): 深入淺出java線程的狀態
“365算法每日學計劃”:04打卡-自己動手寫一個單鏈表
并發基礎篇(四): 深入淺出java線程的狀態
附上熱門QQ群,存放資源和歷史資料,500容量(低門檻付費群),長按二維碼入群
????????????????????????????????????????????? ? ? ? 長按二維碼關注
總結
以上是生活随笔為你收集整理的“面试不败计划”:集合、日期、异常、序列化、其他知识点的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: “365算法每日学计划”:05打卡-图解
- 下一篇: 算法每日学打卡:java语言基础题目打卡