主頁 > 後端開發 > Java列舉解讀

Java列舉解讀

2020-09-14 01:25:58 後端開發

Java列舉

列舉類概念的理解與定義

  • 一個類的物件是有限個,確定的,我們稱此為列舉類,
  • 當需要定義和維護一組常量時,強烈建議使用列舉類,
  • 如果一個列舉類中只有一個物件,則可以作為單例模式的實作方式,
通俗的說:一個類被設計為包含固定實體數量的特殊類,我們給他的定義是列舉類,

注意:
     1.列舉類不能被 new 出來,列舉類因為默認的類修飾符為 final 所以也不能被派生(繼承),同理列舉類也不能為當作實作,
     2.列舉類自身可以實作介面,既可以進行統一實作重寫介面抽象方法,也可以按照列舉型別單個實作重寫,

列舉類的定義

關于列舉類的定義,這塊主要想和大家分享兩種方式

  1. jdk 5.0之前,自定義列舉類方式
  2. jdk 5.0之后,Enum關鍵字方式定義

實踐

一、準備作業

我們新建一個 Java Project ,并創建一個包,以及一個測驗類

二、自定義列舉的三種方式(jdk 5.0 之前)

1. 定義一個抽象類,在抽象類中定義常量進行維護,我們接下來以 Java 類別庫中的 Calendar 類示例來進行說明

新建一個類 EnumDemo01.java 代碼如下:

package org.taoguoguo;
import java.util.Calendar;

/**
 * @author taoGG
 * @description jdk 5.0 之前 抽象類列舉方案Demo
 * @create 2020-09-13 14:20
 */
public class EnumDemo01 {
    public static void main(String[] args) {
        Calendar calendar = Calendar.getInstance();
        System.out.println(calendar.get(1));
    }
}

Console 結果輸出:

2020
Process finished with exit code 0

如果熟悉 Calendar API 的小伙伴 應該馬上能反應過來,這個是獲取當前的年份,類似的值還有

3 - 一年中的第幾個星期
4 - 一年中的第幾個月
5 - 當前的日期 
......

但是這么多值,我們怎么能記得住呢?萬一我輸入錯誤,隨便取了一個范圍怎么辦?

沒錯,這是 jdk 5.0之前的痛點,為了解決實體數量固定,便于維護這些問題,在jdk 5.0之后更新Enum列舉類解決了這個問題,那在jdk 5.0之前官方是怎么做的呢?難道需要我們一個個去記住 Calendar 的數字?

實際上官方本身,采用的就是我們現在說的第一種方式,在抽象類中定義常量進行維護

現在我們將代碼做些修改:

package org.taoguoguo;
import java.util.Calendar;

/**
 * @author taoGG
 * @description jdk 5.0 之前 抽象類列舉方案Demo
 * @create 2020-09-13 14:20
 */
public class EnumDemo01 {
    public static void main(String[] args) {
        Calendar calendar = Calendar.getInstance();
        System.out.println(calendar.get(Calendar.YEAR));
    }
}

我們運行進行輸出:

2020
Process finished with exit code 0

結果與之前一致,這時我們就清楚,在開發程序中作為開發者我們肯定愿意使用 Calendar.YEAR 這種寫法,一來方便記憶,二來可讀性高,那么官方的做法時怎樣的呢?我們點進去原始碼看一下

  1. 首先 Calendar 本身是一個抽象類,實作了序列化、克隆、以及比較排序介面,這邊和我們列舉沒有太大關系,我們繼續往下看

  2. 在抽象類中,定義了很多個靜態常量進行維護,而當我們需要使用時,直接呼叫,這樣就比我們寫一個個的具體值要方便和易用了,

2. 定義一個介面,在介面中定義常量維護列舉值

我們新建一個interface CustomerInf.java

package org.taoguoguo;

/**
 * @author taoGG
 * @description 介面常量維護列舉值
 * @create 2020-09-13 15:47
 */
public interface CustomerInf {
   int RED = 1;
   int GREEN = 2;
   int BLUE = 3;
}

EnumTest 進行測驗

package org.taoguoguo;

/**
 * @author taoGG
 * @description Java列舉測驗類
 * @create 2020-09-13 14:54
 *
 */
public class EnumTest {
    public static void main(String[] args) {
        System.out.println(CustomerInf.RED);
    }
}

測驗結果:

1
Process finished with exit code 0

這種做法我們達到了和在抽象類中維護常量相同的目的,上面這兩種做法都非常的簡單易用,但也有弊端,比如我們只知道一個狀態值,當我們要獲取狀態的屬性或者相關的內容時,我們該怎么做呢?

下面我們使用第三種方式,自定義列舉類,這種基本上達到和 Enum 關鍵字相同的作用,但有一點不足就是會較為復雜

3.自定義列舉類,通過為類私有化構造器和固定實體物件進行列舉維護

新建一個class SeasonEnum.java,代碼如下:

package org.taoguoguo;

/**
 * @author taoGG
 * @description
 * @create 2020-09-13 15:58
 */
public class SeasonEnum {
    //1.宣告列舉物件的屬性
    private final String seasonName;
    private final int code;

    //2.私有化類的構造器
    private SeasonEnum(String seasonName,int code){
        this.seasonName = seasonName;
        this.code = code;
    }

    //3.提供當前列舉類的多個物件 public static final
    public static final SeasonEnum SPRING = new SeasonEnum("春天",100);
    public static final SeasonEnum SUMMER = new SeasonEnum("夏天",200);
    public static final SeasonEnum AUTUMN = new SeasonEnum("秋天",300);
    public static final SeasonEnum WINTER = new SeasonEnum("冬天",400);

    //4.為類提供獲取屬性的方法
    public String getSeasonName() {
        return seasonName;
    }
    public int getCode() {
        return code;
    }
    //5.重寫toString方法
    @Override
    public String toString() {
        return "SeasonEnum{" +
                "seasonName='" + seasonName + '\'' +
                ", code=" + code +
                '}';
    }
}

新建一個class SeasonEnumTest 進行測驗,當我們通過自定義列舉類參考實體物件時,如下圖可以看到,我們已經可以獲取到我們的列舉物件了,

獲取到列舉物件,我們當然也可以獲取到對應的屬性及方法,這種可用性就提高了很多,我們在開發程式進行判斷,可以根據各種列舉值的指定屬性來進行,提高了代碼的可維護性,

SeasonEnumTest 測驗代碼

package org.taoguoguo;

/**
 * @author taoGG
 * @description
 * @create 2020-09-13 16:04
 */
public class SeasonEnumTest {
    public static void main(String[] args) {
        SeasonEnum spring = SeasonEnum.SPRING;
        System.out.println("自定義列舉類物件:" + spring);
        System.out.println("自定義列舉類屬性:" + spring.getSeasonName());
        System.out.println("自定義列舉類屬性:" + spring.getCode());
    }
}

根據我們上面的自定義列舉類方式,我們基本已經實作了列舉的功能了,但是就像上面說到的,如果開發中列舉型別較多,開發多個這樣的自定義列舉類會非常的耗時,所以 jdk 5.0 之后,推出了 Enum 關鍵字定義列舉類

三、Enum 關鍵字定義列舉類(jdk 5.0之后)

enum 全稱為 enumeration,是jdk 5.0 中引入的新特性,在Java 中被 enum 關鍵字修飾的型別就是列舉型別

我們通過代碼來示例來講解和理解 enum 的用法,還是用我們剛剛自定以列舉類的例子,看看使用enum如何來寫

新建一個Java class ,Kind 型別選擇 enum 如圖:

列舉類創建注意:

  • 列舉實體必須在 enum關鍵字宣告的類中顯式的指定(首行開始的以第一個分號結束)
  • 列舉不允許使用new,clone,反射,序列化手動創建列舉實體
package org.taoguoguo;

/**
 * @author taoGG
 * @description
 * @create 2020-09-13 16:23
 */
public enum Season {
    SPRING("春天",100),
    SUMMER("夏天",200),
    AUTUMN("秋天",300),
    WINTER("冬天",400);

    private final String seasonName;
    private final int code;

    Season(String seasonName, int code){
        this.seasonName = seasonName;
        this.code = code;
    }

    public String getSeasonName() {
        return seasonName;
    }
    public int getCode() {
        return code;
    }
}

使用 SeasonTest 測驗類進行測驗:

package org.taoguoguo;

/**
 * @author taoGG
 * @description
 * @create 2020-09-13 16:27
 */
public class SeasonTest {
    public static void main(String[] args) {
        Season spring = Season.SPRING;
        System.out.println(spring);
    }
}

輸出結果:

SPRING
Process finished with exit code 0

注意,在enmu 列舉類中如果沒有重寫 toString方法,會默認使用Enum類本身提供的 toString 方法,回傳列舉類名稱,因為定義的列舉類默認隱式繼承于java.lang.Enum

1.列舉類主要方法介紹

  • values() :該方法可以回傳當前列舉型別的物件陣列,可以很方便的遍歷所有列舉值,一般我們可以根據列舉類的相關屬性通過此方法遍歷獲取對應的列舉物件及列舉值
  • valueOf(String str) : 根據列舉類名稱獲取列舉類物件
  • toString(): 默認使用 java.lang.Enum的 toString方法,回傳當前物件常量的名稱,列舉類推薦重寫回傳自定義友好描述
  • name(): 回傳當前列舉物件名稱,和toString作用上類似,當時toString支持重寫,name方法是不能重寫的,在本質上 toString 也是呼叫的 name方法,列舉定義 name 方法就是為了回傳列舉物件名稱,而 toString 應該根據需要進行重寫
  • ordinal(): 回傳當前列舉物件的序號, 實作了 Comparable 介面,表明它是支持排序的 可以通過 Collections.sort 進行自動排序比較此列舉與指定物件的順序
  • compareTo(): 基于ordinal進行序號大小比較

方式演示代碼,小伙伴們可以自行運行輸出一下,看看各個方法的作用,熟悉一下相關的方法api

package org.taoguoguo;

/**
 * @author taoGG
 * @description
 * @create 2020-09-13 16:27
 */
public class SeasonTest {
    public static void main(String[] args) {
        System.out.println("========values()方法=======");
        for (Season season : Season.values()) {
            System.out.println(season);
        }
        System.out.println("===========================");
 
        System.out.println("========valueOf方法========");
        Season spring = Season.valueOf("SPRING");
        System.out.println(spring);
        System.out.println("===========================");

        System.out.println("========toString方法========");
        System.out.println(spring.toString());
        System.out.println("===========================");

        System.out.println("========name方法========");
        System.out.println(spring.name());
        System.out.println("===========================");

        System.out.println("========ordinal方法========");
        System.out.println(spring.ordinal());
        System.out.println("===========================");

        System.out.println("========compareTo方法========");
        System.out.println(spring.compareTo(Season.WINTER));
        System.out.println("===========================");
    }
}

2.列舉類對介面的實作方式

準備作業

新建一個EnumInf 介面,定義一個抽象方法

package org.taoguoguo;

/**
 * @author taoGG
 * @description
 * @create 2020-09-13 17:25
 */
public interface EnumInf {
    void show();
}

1.實作介面,在enum中統一實作抽象方法

新建一個EnumInf 介面,定義抽象方法 show()

package org.taoguoguo;

/**
 * @author taoGG
 * @description
 * @create 2020-09-13 17:25
 */
public interface EnumInf {
    void show();
}

新建一個OrderStatus 列舉類 實作 EnumInf 介面

package org.taoguoguo;

/**
 * @author taoGG
 * @description
 * @create 2020-09-13 17:27
 */
public enum OrderStatus implements EnumInf{

    SUCCESS(200,"交易成功"),
    Fail(500,"交易失敗");

    private final int code;
    private final String desc;

    OrderStatus(int code, String desc){
        this.code = code;
        this.desc = desc;
    }

    public int getCode() {
        return code;
    }
    public String getDesc() {
        return desc;
    }

    /**
     * 第一種方式,列舉統一重寫介面抽象方法
     */
    @Override
    public void show() {
        System.out.println("訂單列舉物件");
    }
}

進行測驗

package org.taoguoguo;

/**
 * @author taoGG
 * @description
 * @create 2020-09-13 17:32
 */
public class OrderStatusTest {
    public static void main(String[] args) {
        OrderStatus success = OrderStatus.SUCCESS;
        success.show();
    }
}

輸出結果

訂單列舉物件

Process finished with exit code 0

跟我們常用類實作沒有什么區別,列舉也是可以統一實作的,那如果想針對不同的列舉物件進行不同狀態的實作怎么辦呢?比如我們的OA系統、或者電商系統中,根據不同狀態 我們需要回寫對應的資料,下面我們就來看看如何實作,

2.列舉物件分別實作介面中的抽象方法

案例跟介面統一實作一致,我們這邊修改一下OrderStatus 列舉類,代碼如下

package org.taoguoguo;

/**
 * @author taoGG
 * @description
 * @create 2020-09-13 17:27
 */
public enum OrderStatus implements EnumInf{

    SUCCESS(200,"交易成功") {
        @Override
        public void show() {
            System.out.println("回寫交易成功狀態");
        }
    },
    Fail(500,"交易失敗") {
        @Override
        public void show() {
            System.out.println("回寫交易失敗狀態");
        }
    };

    private final int code;
    private final String desc;

    OrderStatus(int code, String desc){
        this.code = code;
        this.desc = desc;
    }

    public int getCode() {
        return code;
    }
    public String getDesc() {
        return desc;
    }

}

我們再修改下測驗類代碼:

package org.taoguoguo;

/**
 * @author taoGG
 * @description
 * @create 2020-09-13 17:32
 */
public class OrderStatusTest {
    public static void main(String[] args) {
        OrderStatus success = OrderStatus.SUCCESS;
        success.show();
        OrderStatus fail = OrderStatus.Fail;
        fail.show();
    }
}

輸出結果

回寫交易成功狀態
回寫交易失敗狀態

Process finished with exit code 0

通過這種方式就可以輕而易舉地定義每個列舉實體不同的行為方式,也達到了我們預期的效果,其實在開發程序中根據列舉的設計和設計模式的鋪墊可以極大的簡化我們的業務代碼,

3.Enum列舉類的工具類及應用場景

1.EnumSet 和 EnumMap

Java 中提供了兩個方便操作enum的工具類——EnumSet 和 EnumMap,

EnumSet 是列舉型別的高性能 Set 實作,它要求放入它的列舉常量必須屬于同一列舉型別,

// EnumSet的使用
System.out.println("EnumSet展示");
EnumSet<OrderStatus> errSet = EnumSet.allOf(OrderStatus.class);
for (OrderStatus e : errSet) {
    System.out.println(e.name() + " : " + e.ordinal());
}

EnumMap 是專門為列舉型別量身定做的 Map 實作,雖然使用其它的 Map 實作(如HashMap)也能完成列舉型別實體到值得映射,但是使用 EnumMap 會更加高效:它只能接收同一列舉型別的實體作為鍵值,并且由于列舉型別實體的數量相對固定并且有限,所以 EnumMap 使用陣列來存放與列舉型別對應的值,(計算機處理連續的資源使用區域記憶體效率更高)這使得 EnumMap 的效率非常高,

// EnumMap的使用
System.out.println("EnumMap展示");
EnumMap<StateMachine.Signal, String> errMap = new EnumMap(StateMachine.Signal.class);
errMap.put(StateMachine.Signal.RED, "紅燈");
errMap.put(StateMachine.Signal.YELLOW, "黃燈");
errMap.put(StateMachine.Signal.GREEN, "綠燈");
for (Iterator<Map.Entry<StateMachine.Signal, String>> iter =errMap.entrySet().iterator(); iter.hasNext();) {
    Map.Entry<StateMachine.Signal, String> entry = iter.next();
    System.out.println(entry.getKey().name() + " : " + entry.getValue());
}
2.列舉類與 Switch 的配合使用

關于列舉與switch是個比較簡單的話題,使用switch進行條件判斷時,條件引數一般只能是整型,字符型,而列舉型確實也被switch所支持,在java 1.7后switch也對字串進行了支持,

實踐

新建一個 BizEnum 的java class,代碼如下

package org.taoguoguo;

/**
 * @author taoGG
 * @description 企業型別列舉
 * @create 2020-09-13 21:24
 */
public enum BizEnum {

    COUNTRIES(101,"國有企業"),

    PRIVETE(102,"私營企業"),

    SOHO(103,"個體單位");

    private final int code;
    private final String desc;

    BizEnum(int code, String desc){
        this.code = code;
        this.desc = desc;
    }

    public int getCode() {
        return code;
    }
    public String getDesc() {
        return desc;
    }

    //根據編碼獲取當前列舉物件的方法
    public static BizEnum getBizTypeByCode(int code){
        for (BizEnum bizEnum : BizEnum.values()) {
            if(code == bizEnum.getCode()){
                return bizEnum;
            }
        }
        return null;
    }
}

結合Switch進行測驗

package org.taoguoguo;

/**
 * @author taoGG
 * @description
 * @create 2020-09-13 21:31
 */
public class BizTest {
    public static void main(String[] args) {
        BizEnum bizType = BizEnum.getBizTypeByCode(101);
        switch (bizType){
            case COUNTRIES:
                System.out.println("國有企業");
                break;
            case PRIVETE:
                System.out.println("私營企業");
                break;
            case SOHO:
                System.out.println("個體單位");
                break;
            default:
                System.out.println("創業中");
        }
    }
}

輸出結果:

國有企業

Process finished with exit code 0

總結

  1. jdk 5.0之前我們可以自定義列舉類,jdk 5.0之后使用enum關鍵字定義列舉類,列舉類默認繼承自java.lang.Enum,使用列舉類將常量組織起來,便于統一管理,例如錯誤碼狀態機等場景中,較為合適使用列舉類,
  2. 列舉類常用方法介紹及列舉類實作抽象類、介面等抽象方法的兩種方式,
  3. 列舉常用的工具類及與switch使用的場景,

轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/29073.html

標籤:Java

上一篇:簡單明了的設計模式-立意篇

下一篇:mybatis 學習筆記

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 【C++】Microsoft C++、C 和匯編程式檔案

    ......

    uj5u.com 2020-09-10 00:57:23 more
  • 例外宣告

    相比于斷言適用于排除邏輯上不可能存在的狀態,例外通常是用于邏輯上可能發生的錯誤。 例外宣告 Item 1:當函式不可能拋出例外或不能接受拋出例外時,使用noexcept 理由 如果不打算拋出例外的話,程式就會認為無法處理這種錯誤,并且應當盡早終止,如此可以有效地阻止例外的傳播與擴散。 示例 //不可 ......

    uj5u.com 2020-09-10 00:57:27 more
  • Codeforces 1400E Clear the Multiset(貪心 + 分治)

    鏈接:https://codeforces.com/problemset/problem/1400/E 來源:Codeforces 思路:給你一個陣列,現在你可以進行兩種操作,操作1:將一段沒有 0 的區間進行減一的操作,操作2:將 i 位置上的元素歸零。最終問:將這個陣列的全部元素歸零后操作的最少 ......

    uj5u.com 2020-09-10 00:57:30 more
  • UVA11610 【Reverse Prime】

    本人看到此題沒有翻譯,就附帶了一個自己的翻譯版本 思考 這一題,它的第一個要求是找出所有 $7$ 位反向質數及其質因數的個數。 我們應該需要質數篩篩選1~$10^{7}$的所有數,這里就不慢慢介紹了。但是,重讀題,我們突然發現反向質數都是 $7$ 位,而將它反過來后的數字卻是 $6$ 位數,這就說明 ......

    uj5u.com 2020-09-10 00:57:36 more
  • 統計區間素數數量

    1 #pragma GCC optimize(2) 2 #include <bits/stdc++.h> 3 using namespace std; 4 bool isprime[1000000010]; 5 vector<int> prime; 6 inline int getlist(int ......

    uj5u.com 2020-09-10 00:57:47 more
  • C/C++編程筆記:C++中的 const 變數詳解,教你正確認識const用法

    1、C中的const 1、區域const變數存放在堆疊區中,會分配記憶體(也就是說可以通過地址間接修改變數的值)。測驗代碼如下: 運行結果: 2、全域const變數存放在只讀資料段(不能通過地址修改,會發生寫入錯誤), 默認為外部聯編,可以給其他源檔案使用(需要用extern關鍵字修飾) 運行結果: ......

    uj5u.com 2020-09-10 00:58:04 more
  • 【C++犯錯記錄】VS2019 MFC添加資源不懂如何修改資源宏ID

    1. 首先在資源視圖中,添加資源 2. 點擊新添加的資源,復制自動生成的ID 3. 在解決方案資源管理器中找到Resource.h檔案,編輯,使用整個專案搜索和替換的方式快速替換 宏宣告 4. Ctrl+Shift+F 全域搜索,點擊查找全部,然后逐個替換 5. 為什么使用搜索替換而不使用屬性視窗直 ......

    uj5u.com 2020-09-10 00:59:11 more
  • 【C++犯錯記錄】VS2019 MFC不懂的批量添加資源

    1. 打開資源頭檔案Resource.h,在其中預先定義好宏 ID(不清楚其實ID值應該設定多少,可以先新建一個相同的資源項,再在這個資源的ID值的基礎上遞增即可) 2. 在資源視圖中選中專案資源,按F7編輯資源檔案,按 ID 型別 相對路徑的形式添加 資源。(別忘了先把檔案拷貝到專案中的res檔案 ......

    uj5u.com 2020-09-10 01:00:19 more
  • C/C++編程筆記:關于C++的參考型別,專供新手入門使用

    今天要講的是C++中我最喜歡的一個用法——參考,也叫別名。 參考就是給一個變數名取一個變數名,方便我們間接地使用這個變數。我們可以給一個變數創建N個參考,這N + 1個變數共享了同一塊記憶體區域。(參考型別的變數會占用記憶體空間,占用的記憶體空間的大小和指標型別的大小是相同的。雖然參考是一個物件的別名,但 ......

    uj5u.com 2020-09-10 01:00:22 more
  • 【C/C++編程筆記】從頭開始學習C ++:初學者完整指南

    眾所周知,C ++的學習曲線陡峭,但是花時間學習這種語言將為您的職業帶來奇跡,并使您與其他開發人員區分開。您會更輕松地學習新語言,形成真正的解決問題的技能,并在編程的基礎上打下堅實的基礎。 C ++將幫助您養成良好的編程習慣(即清晰一致的編碼風格,在撰寫代碼時注釋代碼,并限制類內部的可見性),并且由 ......

    uj5u.com 2020-09-10 01:00:41 more
最新发布
  • Rust中的智能指標:Box<T> Rc<T> Arc<T> Cell<T> RefCell<T> Weak

    Rust中的智能指標是什么 智能指標(smart pointers)是一類資料結構,是擁有資料所有權和額外功能的指標。是指標的進一步發展 指標(pointer)是一個包含記憶體地址的變數的通用概念。這個地址參考,或 ” 指向”(points at)一些其 他資料 。參考以 & 符號為標志并借用了他們所 ......

    uj5u.com 2023-04-20 07:24:10 more
  • Java的值傳遞和參考傳遞

    值傳遞不會改變本身,參考傳遞(如果傳遞的值需要實體化到堆里)如果發生修改了會改變本身。 1.基本資料型別都是值傳遞 package com.example.basic; public class Test { public static void main(String[] args) { int ......

    uj5u.com 2023-04-20 07:24:04 more
  • [2]SpinalHDL教程——Scala簡單入門

    第一個 Scala 程式 shell里面輸入 $ scala scala> 1 + 1 res0: Int = 2 scala> println("Hello World!") Hello World! 檔案形式 object HelloWorld { /* 這是我的第一個 Scala 程式 * 以 ......

    uj5u.com 2023-04-20 07:23:58 more
  • 理解函式指標和回呼函式

    理解 函式指標 指向函式的指標。比如: 理解函式指標的偽代碼 void (*p)(int type, char *data); // 定義一個函式指標p void func(int type, char *data); // 宣告一個函式func p = func; // 將指標p指向函式func ......

    uj5u.com 2023-04-20 07:23:52 more
  • Django筆記二十五之資料庫函式之日期函式

    本文首發于公眾號:Hunter后端 原文鏈接:Django筆記二十五之資料庫函式之日期函式 日期函式主要介紹兩個大類,Extract() 和 Trunc() Extract() 函式作用是提取日期,比如我們可以提取一個日期欄位的年份,月份,日等資料 Trunc() 的作用則是截取,比如 2022-0 ......

    uj5u.com 2023-04-20 07:23:45 more
  • 一天吃透JVM面試八股文

    什么是JVM? JVM,全稱Java Virtual Machine(Java虛擬機),是通過在實際的計算機上仿真模擬各種計算機功能來實作的。由一套位元組碼指令集、一組暫存器、一個堆疊、一個垃圾回收堆和一個存盤方法域等組成。JVM屏蔽了與作業系統平臺相關的資訊,使得Java程式只需要生成在Java虛擬機 ......

    uj5u.com 2023-04-20 07:23:31 more
  • 使用Java接入小程式訂閱訊息!

    更新完微信服務號的模板訊息之后,我又趕緊把微信小程式的訂閱訊息給實作了!之前我一直以為微信小程式也是要企業才能申請,沒想到小程式個人就能申請。 訊息推送平臺🔥推送下發【郵件】【短信】【微信服務號】【微信小程式】【企業微信】【釘釘】等訊息型別。 https://gitee.com/zhongfuch ......

    uj5u.com 2023-04-20 07:22:59 more
  • java -- 緩沖流、轉換流、序列化流

    緩沖流 緩沖流, 也叫高效流, 按照資料型別分類: 位元組緩沖流:BufferedInputStream,BufferedOutputStream 字符緩沖流:BufferedReader,BufferedWriter 緩沖流的基本原理,是在創建流物件時,會創建一個內置的默認大小的緩沖區陣列,通過緩沖 ......

    uj5u.com 2023-04-20 07:22:49 more
  • Java-SpringBoot-Range請求頭設定實作視頻分段傳輸

    老實說,人太懶了,現在基本都不喜歡寫筆記了,但是網上有關Range請求頭的文章都太水了 下面是抄的一段StackOverflow的代碼...自己大修改過的,寫的注釋挺全的,應該直接看得懂,就不解釋了 寫的不好...只是希望能給視頻網站開發的新手一點點幫助吧. 業務場景:視頻分段傳輸、視頻多段傳輸(理 ......

    uj5u.com 2023-04-20 07:22:42 more
  • Windows 10開發教程_編程入門自學教程_菜鳥教程-免費教程分享

    教程簡介 Windows 10開發入門教程 - 從簡單的步驟了解Windows 10開發,從基本到高級概念,包括簡介,UWP,第一個應用程式,商店,XAML控制元件,資料系結,XAML性能,自適應設計,自適應UI,自適應代碼,檔案管理,SQLite資料庫,應用程式到應用程式通信,應用程式本地化,應用程式 ......

    uj5u.com 2023-04-20 07:22:35 more