Java面試題沖刺第十七天--基礎(chǔ)篇3
面試題1:JDK1.8的新特性有哪些?
接口的默認(rèn)和靜態(tài)方法:
Java 8允許我們給接口添加一個非抽象的方法實現(xiàn),只需要使用 default關(guān)鍵字即可,這個特征又叫做擴(kuò)展方法。
public interface JDK8Interface { // static修飾符定義靜態(tài)方法 static void staticMethod() { System.out.println("接口中的靜態(tài)方法"); } // default修飾符定義默認(rèn)方法 default void defaultMethod() { System.out.println("接口中的默認(rèn)方法"); } }
Lambda 表達(dá)式:
例如:(x, y) -> { return x + y; };λ表達(dá)式有三部分組成:參數(shù)列表,箭頭(->),以及一個表達(dá)式或語句塊。
在Java 8 中你就沒必要使用這種傳統(tǒng)的匿名對象的方式了,Java 8提供了更簡潔的語法,lambda表達(dá)式:
Collections.sort(names, (String a, String b) -> { return b.compareTo(a); });
方法與構(gòu)造函數(shù)引用:
Java 8 允許你使用 :: 關(guān)鍵字來傳遞方法或者構(gòu)造函數(shù)引用,上面的代碼展示了如何引用一個靜態(tài)方法,我們也可以引用一個對象的方法:
converter = something::startsWith; String converted = converter.convert("Java"); System.out.println(converted);
函數(shù)式接口:
所謂的函數(shù)式接口,當(dāng)然首先是一個接口,然后就是在這個接口里面只能有一個抽象方法。
Annotation 注解:支持多重注解:
很多時候一個注解需要在某一位置多次使用。
@YourAnnotation @YourAnnotation public void test(){ //TODO }
新的日期時間 API:
Java 8新的Date-Time API (JSR 310)受Joda-Time的影響,提供了新的java.time包,可以用來替代java.util.Date和java.util.Calendar。
一般會用到Clock、LocaleDate、LocalTime、LocaleDateTime、ZonedDateTime、Duration這些類,對于時間日期的改進(jìn)還是非常不錯的。
Base64編碼:
Base64編碼是一種常見的字符編碼,可以用來作為電子郵件或Web Service附件的傳輸編碼。
在Java 8中,Base64編碼成為了Java類庫的標(biāo)準(zhǔn)。Base64類同時還提供了對URL、MIME友好的編碼器與解碼器。
JavaScript引擎Nashorn:
Nashorn允許在JVM上開發(fā)運行JavaScript應(yīng)用,允許Java與JavaScript相互調(diào)用。
Stream的使用:
Stream API是把真正的函數(shù)式編程風(fēng)格引入到Java中。其實簡單來說可以把Stream理解為MapReduce,當(dāng)然Google的MapReduce的靈感也是來自函數(shù)式編程。她其實是一連串支持連續(xù)、并行聚集操作的元素。從語法上看,也很像linux的管道、或者鏈?zhǔn)骄幊?,代碼寫起來簡潔明了,非常酷帥!
Optional:
Java 8引入Optional類來防止空指針異常,Optional類最先是由Google的Guava項目引入的。Optional類實際上是個容器:它可以保存類型T的值,或者保存null。使用Optional類我們就不用顯式進(jìn)行空指針檢查了。
擴(kuò)展注解的支持:
Java 8擴(kuò)展了注解的上下文,幾乎可以為任何東西添加注解,包括局部變量、泛型類、父類與接口的實現(xiàn),連方法的異常也能添加注解。
并行(parallel)數(shù)組:
支持對數(shù)組進(jìn)行并行處理,主要是parallelSort()方法,它可以在多核機(jī)器上極大提高數(shù)組排序的速度。
編譯器優(yōu)化:
Java 8將方法的參數(shù)名加入了字節(jié)碼中,這樣在運行時通過反射就能獲取到參數(shù)名,只需要在編譯時使用-parameters參數(shù)。
其他核心 API 的改進(jìn)
Java IO改進(jìn)
一些IO改進(jìn)包括:
- Files.list(Path dir) 返回延遲填充的Stream,其元素是目錄中的條目。
- Files.lines(Path path) 從文件中讀取所有行作為流。
- Files.find() 通過在以給定起始文件為根的文件樹中搜索文件,返回通過路徑延遲填充的Stream。
- BufferedReader.lines() 返回一個Stream,其元素是從此BufferedReader中讀取的行。
集合 API 的改進(jìn)
我們已經(jīng)看到了 forEach()方法和用于集合的 Stream API。Collection API還有一些新方法是:
- Iterator forEachRemaining(Consumer action)在所有元素都已處理完畢或該動作引發(fā)異常之前,對每個剩余元素執(zhí)行給定操作的默認(rèn)方法。
- Collection removeIf(Predicate filter)刪除此集合中所有滿足特定條件的元素的默認(rèn)方法。
- Collection spliterator() 該方法返回Spliterator實例,該實例可用于順序或并行遍歷元素。
- map replaceAll(),compute(),merge()方法。
- 具有鍵沖突的HashMap類的性能改進(jìn)
面試題2:什么是內(nèi)部類?內(nèi)部類的作用?
將一個類定義在另一個類或者另一個方法里面,這樣的類稱著內(nèi)部類;值得注意的是,內(nèi)部類能夠訪問外部類的所有成員,包括private修飾的。
舉例:把類Inner定義在類Outer中,類Inner就被稱為內(nèi)部類。
class Outer { class Inner { } }
注意:
內(nèi)部類是一個編譯時的概念,一旦編譯成功,就會成為完全不同的兩類。對于一個名為 outer 的外部類和其內(nèi)部定義的名為 inner 的內(nèi)部類。編譯完成后出現(xiàn) outer.class 和 outer$inner.class 兩類。所以內(nèi)部類的成員變量/方法名可以和外部類的相同。
內(nèi)部類的作用
1、內(nèi)部類可以很好的實現(xiàn)隱藏。
非內(nèi)部類是不可以使用 private和 protected修飾的,但是內(nèi)部類卻可以,從而達(dá)到隱藏的作用。同時也可以將一定邏輯關(guān)系的類組織在一起,增強(qiáng)可讀性。
2、間接的實現(xiàn)多繼承。
內(nèi)部類提供了Java的"多重繼承"的解決方案,彌補(bǔ)了Java類是單繼承的不足
每個內(nèi)部類都能獨立地繼承自一個(接口的)實現(xiàn),所以無論外部類是否已經(jīng)繼承了某個(接口的)實現(xiàn),對于內(nèi)部類都沒有影響。如果沒有內(nèi)部類提供的可以繼承多個具體的或抽象的類的能力,一些設(shè)計與編程問題就很難解決。所以說內(nèi)部類間接的實現(xiàn)了多繼承。
內(nèi)部類特點
- 內(nèi)部類仍然是一個獨立的類,在編譯之后內(nèi)部類會被編譯成獨立的.class文件,但是前面冠以外部類的類名和$符號
- 內(nèi)部類不能用普通的方式訪問。內(nèi)部類是外部類的一個成員,因此內(nèi)部類可以自由地訪問外部類的成員變量,無論是否是private的
- 內(nèi)部類聲明成靜態(tài)的,就不能隨便的訪問外部類的成員變量了,此時內(nèi)部類只能訪問外部類的靜態(tài)成員變量
面試題3:內(nèi)部類有哪幾種?分別介紹一下
成員內(nèi)部類
局部內(nèi)部類
靜態(tài)內(nèi)部類
匿名內(nèi)部類
成員內(nèi)部類
成員內(nèi)部類——就是位于外部類成員位置的類
public class Outer { //不對外開放的 class Inner{ public void show(){ System.out.println("成員內(nèi)部類"); } } }
特點:
- 內(nèi)部類就像一個實例成員一樣存在于外部類中。
- 內(nèi)部類可以訪問外部類的所有成員就想訪問自己的成員一樣沒有限制。
- 內(nèi)部類中的 this 指的是內(nèi)部類的實例對象本身,如果要用外部類的實例對象就可以用類名 .this 的方式獲得。
- 內(nèi)部類對象中不能有靜態(tài)成員,原因很簡單,內(nèi)部類的實例對象是外部類實例對象的一個成員。
局部內(nèi)部類
局部內(nèi)部類——就是定義在一個方法或者一個作用域里面的類;
class Outer { public void method(){ class Inner { System.out.println("局部內(nèi)部類"); } } }
特點:
- 方法中的內(nèi)部類沒有訪問修飾符, 即方法內(nèi)部類對包圍它的方法之外的任何東西都不可見。
- 方法內(nèi)部類只能夠訪問該方法中的局部變量,所以也叫局部內(nèi)部類。而且這些局部變量一定要是final修飾的常量。
靜態(tài)內(nèi)部類
我們所知道static是不能用來修飾類的,但是成員內(nèi)部類可以看做外部類中的一個成員,所以可以用static修飾,這種用static修飾的內(nèi)部類我們稱作靜態(tài)內(nèi)部類,也稱作嵌套內(nèi)部類.
特點:不能使用外部類的非static成員變量和成員方法
class Outter { int age = 10; static age2 = 20; public Outter() { } static class Inner { public method() { System.out.println(age);//錯誤 System.out.println(age2);//正確 } } } public class Test { public static void main(String[] args) { Outter.Inner inner = new Outter.Inner(); inner.method(); } }
匿名內(nèi)部類
一個沒有名字的類,是內(nèi)部類的簡化寫法
本質(zhì):其實是繼承該類或者實現(xiàn)接口的子類匿名對象
public abstract class A implements B{ public void A(){ System.out.println("A"); } }
public interface B{ public void B(); }
public class Test { public static void main(String[] args) { //new出接口或者實現(xiàn)類 A a= new A (){ //實現(xiàn)接口里未實現(xiàn)的方法 public void B() { System.out.println("匿名內(nèi)部類"); } }; a.A(); a.B(); }
特點:
一個類用于繼承其他類或是實現(xiàn)接口,并不需要增加額外的方法,只是對繼承方法的事先或是覆蓋。
只是為了獲得一個對象實例,不需要知道其實際類型。
類名沒有意義,也就是不需要使用到。 每日小結(jié)
總結(jié)
本篇文章就到這里了,希望能給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
程序包org.springframework不存在的解決辦法
這篇文章主要介紹了程序包org.springframework不存在的解決辦法,在使用IDEA創(chuàng)建SpringBoot項目時,剛打開無法正常運行,本文通過圖文結(jié)合的方式給大家介紹的非常詳細(xì),具有一定參考價值,需要的朋友可以參考下2024-07-07MyBatis存儲過程、MyBatis分頁、MyBatis一對多增刪改查操作
本文通過一段代碼給大家介紹了MyBatis存儲過程、MyBatis分頁、MyBatis一對多增刪改查操作,非常不錯,具有參考借鑒價值,感興趣的朋友一起看看吧2016-11-11Java觀察者設(shè)計模式(Observable和Observer)
這篇文章主要介紹了 Java觀察者設(shè)計模式(Observable和Observer)的相關(guān)資料,需要的朋友可以參考下2015-12-12解決IDEA開發(fā)工具右側(cè)沒有Maven工具欄的問題
這篇文章主要給大家解決了IDEA開發(fā)工具右側(cè)沒有Maven工具欄的問題,文中有詳細(xì)的解決步驟,如果有遇到一樣問題的小伙伴,可以參考閱讀本文2023-09-09Spring Boot JPA中java 8 的應(yīng)用實例
這篇文章主要介紹了Spring Boot JPA中java 8 的應(yīng)用實例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02