本文将为大家介绍C#13的属性语法优化,同时回顾属性的所有写法。
众所周知,C#的属性相对于对标语言,比如说Java,是一个超级甜点。C#13更进一步,在属性的getter和settter中,引入了field关键字,表示后备字段(backing field),这样可以少写一行模板代码,更加的简洁,属性也更具有独立人格(更像一种独立成员了)。大家看一下面这段代码,是不是很爽?
//之前,如果我们要使用getter和setter,控制Age的读取和写入,需要添加后备字段
public class Person
{
private int _age;
public int Age
{
get => _age /2;
set => age * 2;
}
}
//C#13,我们可以这样写了,爽哇~~~
//field是一个新的关键词,表示该属性的后备字段
//减少了一行烦人的模板代码
//这样的属性是不是更有独立人格了?
public class Person
{
public int Age
{
get => field /2;
set => field * 2;
}
}
Java这时候肯定又要说,切~~~啥玩意,我一个get和set方法,搞定全部,弄这么多语法糖干啥,多增加心智负担呀,“一招鲜,吃遍天 ”不香嘛!!!
嗯~~~,我们还是忆苦思甜,回顾一下C#的属性,看它是如何一步步走过来了,一个属性要走到今天这个样子,并不容易。但语言要发展,始终是要迈开步子往前走。咱们也顺便做做代码体操,复习一下。
public MyClass
{
//最开始一个完整的属性
//初诞生时,如果熟悉了Java的get和set方法,可能会觉得有些别扭
private int _myProperty1; //未初始化,默认值为0
public int MyProperty1
{
get { return _myProperty; }
set { _myProperty = value; }
}
//使用Lambda简化
private int _myProperty2;
public string MyProperty2
{
get => _myProperty2;
set => _myProperty2 = value;
}
//再次简化,省略了后备字段
//很简洁,但无法定制具体的get和set方法
public int MyProperty3{ get;set } //简写方式②:最简化
public int MyProperty4{ get; } = 10; //只读属性初始化方式1,有后备字段
public int MyProperty5 => 10;//只读属性初始化方式2,无后备字段
public int MyProperty6 { get; private set; } //只在类的内部可写
public int MyProperty7 { get; protected set; } //只在派生类中可写
public int MyProperty8 { get; internal set; } //只在程序集中可写
public int MyProperty9 { get; protected internal set; } //只在派生类或程序集中可写
public int MyProperty10 { get; init; } //在构造函数或初始化构造器中初始化
}
有了field,玩XAML的兄弟姐妹们,有没有一点小兴奋,以后咱们可能就可以像下面这么写MVVM了>>>!!!
public class MyViewModel : BindableBase
{
//属性
//注意看,所有属性的get和set的模板代码是一样的,是否可以进一步简化?
public string MyProperty1
{
get { return field; }
set { SetProperty(ref field, value); }
}
//命令
public ICommand MyCommand => field ??= new DelegateCommand(Execute, CanExecute);
}
瞬间CommunityToolkit.Mvvm也不那么香了!!!
其实,省略后备字段模板代码的提案在C#12就有了,但那个时候还不够香(比如使用“@field”这样的关键字),但这次够香了,不要鸽呀~~~
你期待这个语法糖吗???兄弟们评论区交流~~~
我是functionMC > function MyClass(){…}
C#/TS/鸿蒙/AI/中美科技竞争等问题,以及如何写Bug、防脱发、送外卖等问题,都可以私信我提问哦!