您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關怎么在C#9中將records作為強類型ID,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
實體通常是整數,GUID或者string類型,因為數據庫直接支持這些類型,但是,如果實體的ID的類型是一樣的,比如都是整數的ID,這有可能會出現ID值傳錯的問題,看下邊的示例。
public void AddProductToOrder(int orderId, int productId, int count) { ... } ... // 這個地方,參數傳錯了 AddProductToOrder(productId, orderId, int count);
上面的代碼可以很好地通過檢查并編譯,但是在運行的時候就出問題了,這是邏輯bug。
幸運的是,可以定義強類型id來解決這個問題,這個想法很簡單,為每個實體的ID聲明一個特定的類型,現在需要這樣寫:
// 使用強類型ID代替整數ID public void AddProductToOrder(OrderId orderId, ProductId productId, int count) { ... } ... // 這個地方,參數傳錯了 AddProductToOrder(productId, orderId, int count);
在上面的代碼中,我們犯了與第一個示例相同的錯誤(交換productId和orderId),但是在這種情況下,類型不同,因此編譯器會捕獲該錯誤并報告錯誤,我們仍然需要對其進行修復,但是至少在生產中并沒有爆炸。
public readonly struct ProductId : IEquatable<ProductId> { public ProductId(int value) { Value = value; } public int Value { get; } public bool Equals(ProductId other) => other.Value == Value; public override bool Equals(object obj) => obj is ProductId other && Equals(other); public override int GetHashCode() => Value.GetHashCode(); public override string ToString() => $"ProductId {Value}"; public static bool operator ==(ProductId a, ProductId b) => a.Equals(b); public static bool operator !=(ProductId a, ProductId b) => !a.Equals(b); }
上面的代碼沒什么難的,但是如果每個實體都需要的話,那確實有點麻煩,在C# 9 可以使用source generators來完成這些,但是C# 9還引入了另一個功能,使用起來更方便。
Record 類型是具有內置不變性和值語義的引用類型,它和上面我們寫的強類型是一樣的(手動寫的成員實現Equals,GetHashCode等等),在代碼中使用也非常簡潔, 如果我們ProductId使用record重寫類型,就是下邊這樣:
public record ProductId(int Value);
是的,您沒看錯,這是一行,而上面的代碼是一大段,它完成了我們手動執行的所有操作(實際上,還多了很多!)。
主要區別在于:我們的手動實現是struct,即值類型,但是記錄是引用類型,這意味著它們可以為null,這可能不是主要問題,尤其是在使用可為空的引用類型的情況下,但是要知道這一點。
以上就是怎么在C#9中將records作為強類型ID,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。