.NET6新特新?struct優(yōu)化
在.NET6中針對Struct做了一些優(yōu)化,下面我們就通過一些案例來看一下.NET6中針對Struct的優(yōu)化。
一、Record Struct
雖然在上一個版本中就有了record,但是上一版本中的的record是class是一個引用類型,但是record struct是值類型是一個結(jié)構(gòu),
它的使用方式如下:
record struct Point(int X, int Y);
在.NET6中也支持record來聲明一個基于class的record,這和原來的record是一樣的,例如? ?record class RecordModel(int Id, string Name) ??`? ?這和 ??`? ?record RecordModel(int Id, string Name)?? record struct會自動生成Equals和GetHashCode并重寫==和!=操作符,并且可以用with修改部分屬性創(chuàng)建新的對象。如果record struct聲明有參數(shù)構(gòu)造器,則會生成一個隱式的無參構(gòu)造。
代碼如下:? ? ?
var p1 = new Point(1, 2);
var p2 = p with { X = 2 };
Console.WriteLine(p1);
Console.WriteLine(p2);
Console.WriteLine(new Point());
運(yùn)行上述代碼可以看到即使沒有顯式聲明無參構(gòu)造還是會生成一個無參構(gòu)造來初始化。
上述代碼輸出如下:
Point { X = 1, Y = 2 }
Point { X = 2, Y = 2 }
Point { X = 0, Y = 0 }
二、readonly struct record
我們可以使用readonly來標(biāo)記結(jié)構(gòu)體,也可以使用readonly struct record,但record struct不能使用ref修飾。使用readonly struct record聲明的結(jié)構(gòu)體,如果使用Primary Constructor對應(yīng)的屬性會是init。例如? ?readonly record struct Point(int X, int Y);??
屬性的聲明是這樣的:
internal readonly struct Point : IEquatable
{
public int X { get; init; }
public int Y { get; init; }
public Point(int X, int Y)
{
this.X = X;
this.Y = Y;
}
}
三、Parameterless Constructor
.NET6支持用戶自定義無參構(gòu)造方法,我們可以在無參構(gòu)造方法中加入初始化邏輯,
代碼如下如下:
Console.WriteLine(new Point1().ToString());
Console.WriteLine(default(Point1).ToString());
Console.WriteLine(Activator.CreateInstance());
struct Point1
{
public int X { get; set; }
public int Y { get; set; }
private int Z { get; set; }
public Point1()
{
X = 1;
Y = 2;
Z = 3;
}
public override string ToString()
{
return $"{X}_{Y}_{Z}";
}
}
這里需要注意default和new的差別,default是結(jié)構(gòu)體空狀態(tài),不會執(zhí)行無參構(gòu)造,new是會執(zhí)行,通過反射創(chuàng)建對象的時候也會執(zhí)行構(gòu)造,
代碼輸出結(jié)果如下:
1_2_3
0_0_0
1_2_3
除了record之外,.NET6還擴(kuò)展了with表達(dá)式用法,普通結(jié)構(gòu)體和匿名對象也可以使用with來修改部分屬性
代碼如下:
Console.WriteLine((new Point1() with { X = 2 }).ToString());
Console.WriteLine();
var obj = new
{
X = 1,
Y = 1
};
Console.WriteLine(JsonSerializer.Serialize(obj));
Console.WriteLine(JsonSerializer.Serialize(obj with { X = 3, Y = 3 }));
輸出結(jié)果如下:
2_2_3
{"X":1,"Y":1}
{"X":3,"Y":3}
with只能對public成員進(jìn)行操作,上面代碼中的Z是private,因此在with表達(dá)式中是不能指定。 和record class相比record struct沒有 Clone 方法,因為struct不需要自帶Clone功能,record struct不允許聲明Clone成員方法,所有record都不允許聲明Clone 成員。
到此這篇關(guān)于 NET6新特新 struct優(yōu)化的文章就介紹到這了,更多相關(guān) NET6 struct優(yōu)化內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
.Net Core HttpClient處理響應(yīng)壓縮詳細(xì)
.Net Core作為后起之秀直接將HttpClient扶正,并且在此基礎(chǔ)上改良了HttpClientFactory,接下來我們就來探究一下在.Net Core中使用HttpClient處理響應(yīng)壓縮的機(jī)制。,需要的朋友可以參考下面文章的具體內(nèi)容2021-09-09
ASP.NET MVC Web API HttpClient簡介
依稀還記得那個時候用WebClient,HttpWebRequest來發(fā)送一個請求,現(xiàn)在ASP.NET MVC4中自帶了一個類HttpClient;需要的朋友可以參考下2012-11-11
ASP.NET Core如何注入多個服務(wù)實現(xiàn)類
這篇文章主要介紹了ASP.NET Core如何注入多個服務(wù)實現(xiàn)類的相關(guān)資料,需要的朋友可以參考下面文章的具體內(nèi)容2021-09-09
.NET 6新特性試用Timer類之PeriodicTimer?
這篇文章主要介紹了.NET 6新特性試用Timer類之PeriodicTimer,PeriodicTimer與其他Timer需要創(chuàng)建事件回調(diào)不同,下,下面文章詳細(xì)介紹PeriodicTimer的使用方式,需要的朋友可以參考一下2022-02-02
修改 asp.net core 5 程序的默認(rèn)端口號
這篇文章主要介紹了修改 asp.net core 5 程序的默認(rèn)端口號,我們知道可以通過修改 launchSettings.json 文件中的端口號來實現(xiàn)端口切換,下面來看看具體的修改過程吧2022-01-01

