中文字幕第五页-中文字幕第页-中文字幕韩国-中文字幕最新-国产尤物二区三区在线观看-国产尤物福利视频一区二区

JDK8新增了哪些內容

這期內容當中小編將會給大家帶來有關JDK8的新增內容以及新特性的使用方法,以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

站在用戶的角度思考問題,與客戶深入溝通,找到灤南網站設計與灤南網站推廣的解決方案,憑借多年的經驗,讓設計與互聯網技術結合,創造個性化、用戶體驗好的作品,建站類型包括:成都網站制作、成都做網站、外貿營銷網站建設、企業官網、英文網站、手機端網站、網站推廣、域名與空間、網絡空間、企業郵箱。業務覆蓋灤南地區。

函數式編程

面向對象強調“一切皆對象”,如果想要做事情,必須要找到對象來做。函數式編程思想強調“做什么”,而不是“怎么做”。

普通的開啟線程

// 匿名內部類對象
Runnable task = new Runnable() {
    @Override
    public void run() {
        System.out.println("烏鴉坐飛機");
    }
};
new Thread(task).start();

函數式編程開啟線程

new Thread(() -> System.out.println("龍卷風摧毀停車場")).start();

前面的小括號:方法參數,沒有參數時就寫(),箭頭指向后面要做的事情,箭頭后面就好比是方法體大括號,代表具體要做的內容。

Lambda表達式

Lambda表達式,也可稱為閉包,它是推動 Java 8 發布的最重要新特性。

Lambda 允許把函數作為一個方法的參數(函數作為參數傳遞進方法中)。使用 Lambda 表達式可以使代碼變的更加簡潔緊湊。

三要素:參數、箭頭 、代碼

格式:(參數類型 參數名稱) -> { 一些代碼 }

使用Lambda表達式的前提:必須要有接口并且接口中有且只有一個抽象方法

演示:編寫一個Cook接口,接口中有一個makeFood()方法

public static void main(String[] args) {
    method(() -> {
        System.out.println("閃刀啟動!");
    });
}
 
private static void method(Cook cook) {
    cook.makeFood();
}

Lambda表達式省略規則:

參數類型可以省略。但是只能同時省略所有參數的類型,或者干脆都不省略如果參數有且僅有一個,那么小括號可以省略如果大括號內的語句有且僅有一個,那么無論有沒有返回值,return、大括號、分號都可以省略。

    public static void main(String[] args) {
        method((a, b)-> a + b);
    }
 
    private static void method(Calculator calculator) {
        int result = calculator.sum(1234, 9876);
        System.out.println(result);
    }

在new一個接口時,也可以使用lambda表達式來代替匿名內部類

Runnable task = () -> System.out.println("閃刀啟動!");
new Thread(task).start();

函數式接口

接口當中有且僅有一個抽象方法,叫做函數式接口。

JDK8中新增了注解@FunctionalInterface,用于檢測一個接口是否為函數式接口。如果不是函數式接口,編譯時會報錯。@FunctionalInerface注解是可選的,就算不用這個注解,只要保證接口滿足函數式接口的定義要求,也一樣是函數式接口。

@FunctionalInterface
public interface MyInterface {
    void method();
}

方法引用

Printer printer = (str) -> System.out.println(str);這段代碼實際上可以簡寫。

只要是可推導的,就是可引用的,因此傳參其實并沒有意義,因此這里其實可以使用方法引用來簡寫 System.out::println

從java8開始,引入了一個全新的運算符,方法引用符(兩個冒號連著寫),所在的表達式就是一個方法引用,方法引用和Lambda本質是完全一樣的,目的就是簡化Lambda表達式的寫法。

Lambda的寫法:s->System.out.println(s)

方法引用寫法:System.out::println

兩種寫發完全等效

 
    public static void main(String[] args) {
        method(System.out::println);
    }
 
    private static void method(Printer printer) {
        printer.print("hello");
    }

接口

default方法

接口本來是兩個抽象方法,現在需要變成三個抽象方法,這個時候它的實現類也需要實現新的方法。

當實現類太多時,操作起來很麻煩,JDK之前是使用開閉設計模式:對擴展開放,對修改關閉。即:創建一個新的接口,繼承原有的接口,定義新的方法,但是這樣的話,原本的那些實現類并沒有新的方法,這時候可以使用接口默認方法。

關鍵字使用default進行修飾, 方法需要方法體。這樣的方法所有的子類會默認實現(不用自己寫),如果想要覆蓋重寫,也可以在實現類中覆蓋重寫

/**
 * 從java8開始,接口當中允許定義default默認方法
 * 修飾符:public default(public可以省略,default不能省略)
 */
public interface MyInterface {
 
    void method1();
 
    void method2();
 
    default void methodNew() {
        System.out.println("接口默認方法執行");
    }
 
}

注意:接口中的default方法相當于是一個新的關鍵字,和四種修飾符的“default”并非一個概念。

活用default關鍵字,可以使程序達到“多繼承”的效果。

static方法

從java8開始,接口當中允許定義靜態方法,用法與一般類的靜態方法相同。

public interface Animal {
 
    void eat();
 
    static Animal getAnimal() {
        return new Cat();
    }
}

流式操作

流式處理給開發者的第一感覺就是讓集合操作變得簡潔了許多,通常我們需要多行代碼才能完成的操作,借助于流式處理可以在一行中實現。

比如我們希望對一個包含整數的集合中篩選出所有的偶數,并將其封裝成為一個新的List返回,那么在java8之前,我們需要通過如下代碼實現:

對于一個nums的集合:

List<Integer> evens = new ArrayList<>();
for (final Integer num : nums) {
    if (num % 2 == 0) {
        evens.add(num);
    }
}

通過java8的流式處理,我們可以將代碼簡化為:

List<Integer> evens = nums.stream().filter(num -> num % 2 == 0).collect(Collectors.toList());

先簡單解釋一下上面這行語句的含義,stream()操作將集合轉換成一個流,filter()執行我們自定義的篩選處理,這里是通過lambda表達式篩選出所有偶數,最后我們通過collect()對結果進行封裝處理,并通過Collectors.toList()指定其封裝成為一個List集合返回。

常用操作案例:

        //初始化list集合
        List<String> list = new ArrayList<String>();
        list.add("測試數據1");
        list.add("測試數據2");
        list.add("測試數據3");
        list.add("測試數據12");
        
        //使用λ表達式遍歷集合
        list.forEach(s -> System.out.println(s));
        
        //結合Predicate使用和過濾條件篩選元素
        Predicate<String> contain1 = n -> n.contains("1");
        Predicate<String> contain2 = n -> n.contains("2");
        
        //根據條件遍歷集合
        list.stream().filter(contain1).forEach(n -> System.out.println(n));
        list.stream().filter(s -> contain1.test(s)).forEach(s -> System.out.println(s));
        list.stream().filter(contain1.and(contain2)).forEach(n -> System.out.println(n));
        list.stream().filter(contain1.or(contain2)).forEach(n -> System.out.println(n));
        
        //將過濾后的元素重新放到一個集合中
        List<String> newList = list.stream().filter(contain1.and(contain2)).collect(Collectors.toList());
        
集合中decimal求和
		BigDecimal sum = list
				.stream()
				.map(Person::getAmount)
				.reduce(BigDecimal::add)
				.get();
 
//排序 , 也需要新的集合接收
	List<Student> resultList = new ArrayList<Student>();
	resultList = list.stream().sorted(Comparator.comparing(Student::getAge)).collect(Collectors.toList())

上述就是小編為大家分享的JDK8的新增內容了,如果您也有類似的疑惑,不妨參照上述方法進行嘗試。如果想了解更多相關內容,請關注創新互聯行業資訊。

網頁標題:JDK8新增了哪些內容
文章起源:http://www.2m8n56k.cn/article8/pchpop.html

成都網站建設公司_創新互聯,為您提供網站設計電子商務網站排名搜索引擎優化品牌網站建設

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:[email protected]。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

網站托管運營
主站蜘蛛池模板: 高清在线一区二区 | 美国毛片亚洲社区在线观看 | 韩国主播19福利视频在线 | 国模偷拍在线观看免费视频 | 亚洲精品欧洲一区二区三区 | 精品国产网 | 综合色久七七综合七七蜜芽 | 久草一级片 | 成人在线播放 | 亚洲欧美日韩国产精品影院 | 日本三级在线观看中文字 | 亚洲毛片一级巨乳 | 91精品乱码一区二区三区 | 天天碰夜夜操 | 波多野结衣福利视频 | 国产精品一区二区久久精品涩爱 | 亚洲毛片在线 | 小泽玛利亚的一级毛片的 | 欧美成人综合在线观看视频 | 亚洲国产成人久久三区 | 国产成人精品永久免费视频 | 亚洲欧美精品中文字幕 | 日韩高清不卡在线 | 国产精品高清视亚洲精品 | 国产一级aaa全黄毛片 | 国产精品一级 | 久久午夜影院 | 日韩特黄毛片 | 国内自拍网红在线综合 | 美女做爰视频在线观看免费 | 热re91久久精品国产91热 | 经典日韩 | 欧美三级不卡视频 | 视频三区精品中文字幕 | 男人的天堂久久爱 | 喷潮白浆直流在线播放 | 国产精品成aⅴ人片在线观看 | 欧美日韩精品在线视频 | 欧美高清日本三级人妇 | 91精品国产综合久久久久 | 亚洲欧美在线播放 |