我在.NET Core 3.0项目上启用C#8.0可空引用类型。该项目使用Entity Framework Core 3.0访问数据库。
以下是标题不应为null的数据模型。
public class Vehicle
{
public int Id { get; private set; }
public string Title { get; private set; }
// Entity Framework Core is instructed to bind to the private _drivers field in a configuration builder
private readonly List<Driver> _drivers = new List<Driver>();
public IReadOnlyCollection<Driver> Drivers => _drivers.AsReadOnly();
private Vehicle()
{
}
public Vehicle(string title)
{
this.Title = title;
}
public void AddDriver(string name)
{
this._drivers.Add(new Driver(name));
}
}
// A foreign column is defined in a configuration builder
public class Driver
{
public int Id { get; private set; }
public string Name { get; private set; }
private Driver()
{
}
public Driver(string name)
{
this.Name = name;
}
}
public
仅当private
构造函数仅用于实体框架核心和(可能还)序列化将数据库中的值绑定到这些类/模型时,才应使用自己的代码。公共构造函数的参数结构,列表和类型可能与模型具有的属性不同(例如,它可能还包含第一个必需子级的参数,它可能具有一些可选参数等)。
但是,编译器会CS8618 Non-nullable field is uninitialized. Consider declaring as nullable.
在private
构造函数上生成。
我可以通过private
构造器禁用CS8616,#pragma warning disable CS8618
但我认为这不是一个好主意。
在这种情况下应该如何使用C#8.0可空引用类型?还是我的模型虚假或违反了最佳做法-如何正确执行?
不幸的是,我没有找到相关的文档或指南。