首頁 > 軟體

Java匿名內部類和Lambda(->) 的多種寫法總結

2022-07-29 22:05:41

引入: 最近使用到 Arrays.sort(); 看了他的過載方法(試著模仿一下)

就以這個玩出了許多的方式;如下:自定義排序

首先 寫了個氣泡排序(備用)

		//給一個integres 的陣列, 然後再給個 Comparator的介面 c
	/**
     *
     * @param  integers 給一個 integres 的陣列,作為要排序的陣列
     * @param c  接受一個 Comparator 介面 ,然後使用Comparator 重寫的 compare 方法
     */
 public static void bubbleSort(Integer[] integers,Comparator c ){

        int temp;
        
        for(int i = 0 ; i < integers.length-1;i++){
            for(int j = 0 ; j < integers.length -1 -i;j++){
            
			//判斷是從大到小還是從小到大
                if(c.compare(integers[j] , integers[j+1]) > 0){
                    
                    //慢
                    /*integers[j] += integers[j+1];
                    integers[j+1] = integers[j] - integers[j+1];
                    integers[j] = integers[j] - integers[j+1];*/

                    //更快
                    temp = integers[j];
                    integers[j] = integers[j+1];
                    integers[j+1] = temp;

                }
            }
        }


    }

認識幾種寫法

第一種寫法

    //第一種寫法 匿名類寫法
        bubbleSort(number, new Comparator() {
            @Override
            public int compare(Object o1, Object o2) {
                return (int)o1 - (int)o2;
            }
        });

第二種寫法(Lambda)

        // 接受2個引數(數位),並返回他們的差值  
        // (x, y) -> x – y  
        //第二種寫法
        bubbleSort(number, (Object o1 ,Object o2)-> (int)o1 - (int)o2);

第三種寫法(Lambda)

        /*第三種寫法
        * 1.先把Object 轉為 int 然後執行以下操作
        * Comparator.comparingInt((Object o) -> (int) o);
        * 
        * 2.會返回 (c1, c2)  -> Integer.compare(keyExtractor.applyAsInt(c1), keyExtractor.applyAsInt(c2));
        * 會讀取兩個物件 keyExtractor.applyAsInt(c1) , keyExtractor.applyAsInt(c2)
        * 
        * 3.(Comparator.comparingInt((Object o) -> (int) o)))讀取一個(keyExtractor.applyAsInt(c1))後返回到這裡(Comparator.comparingInt((Object o) -> (int) o))),然後再讀取一個(keyExtractor.applyAsInt(c2))
        * 
        * 4.兩個了之後就開始比較Integer.compare
        * public static int compare(int x, int y) {
        *        return (x < y) ? -1 : ((x == y) ? 0 : 1);
        *    }
        *5.最後經過三元運運算元後 返回對應的數
        */
        
        bubbleSort(number, Comparator.comparingInt((Object o) -> (int) o));

然後開始使用

import java.util.Arrays;
import java.util.Comparator;

public class Test {
    public static void main(String[] args) {
        Integer number[] = {1,4,2,23,32,43};
		//第一種寫法
        bubbleSort(number, new Comparator() {
            @Override
            public int compare(Object o1, Object o2) {
                return (int)o1 - (int)o2;
            }
        });
        
		//第二種寫法
        //1.先把Object 轉為 int 然後執行以下操作
        //Comparator.comparingInt((Object o) -> (int) o);
        //2.會進去 (c1, c2) -> Integer.compare(keyExtractor.applyAsInt(c1), keyExtractor.applyAsInt(c2));
        //然後會讀取兩個物件keyExtractor.applyAsInt(c1) , keyExtractor.applyAsInt(c2)
        //3.Comparator.comparingInt((Object o) -> (int) o)) 讀取一個後返回到這裡,然後再讀取一個
        //4.兩個了之後就開始比較Integer.compare
        // public static int compare(int x, int y) {
        //        return (x < y) ? -1 : ((x == y) ? 0 : 1);
        //    }
        //5.返回 最後的數
        bubbleSort(number, Comparator.comparingInt((Object o) -> (int) o));

		//第三種寫法
        bubbleSort(number, (Object o1 ,Object o2)-> (int)o1 - (int)o2);


        System.out.println("排序後的陣列"+Arrays.toString(number));
        
   		 }
   		 

   //給一個integres 的陣列, 然後再給個 Comparator的介面 c
	/**
     *
     * @param  integers 給一個 integres 的陣列,作為要排序的陣列
     * @param c  接受一個 Comparator 介面 ,然後使用Comparator 重寫的 compare 方法
     */
 public static void bubbleSort(Integer[] integers,Comparator c ){

        int temp;
        
        for(int i = 0 ; i < integers.length-1;i++){
            for(int j = 0 ; j < integers.length -1 -i;j++){
            
			//判斷是從大到小還是從小到大
                if(c.compare(integers[j] , integers[j+1]) > 0){
                    
                    //慢
                    /*integers[j] += integers[j+1];
                    integers[j+1] = integers[j] - integers[j+1];
                    integers[j] = integers[j] - integers[j+1];*/

                    //更快
                    temp = integers[j];
                    integers[j] = integers[j+1];
                    integers[j+1] = temp;

                }
            }
        }


   	 }
    }

到此這篇關於Java匿名內部類和Lambda(->) 的多種寫法總結的文章就介紹到這了,更多相關Java匿名內部類 Lambda內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com