Как указатель по умолчанию оператора С# по умолчанию обрабатывает нулевое перечисление?
Будет ли утеряна по умолчанию метка null и любые необработанные случаи?
Как указатель по умолчанию оператора С# по умолчанию обрабатывает нулевое перечисление?
Будет ли утеряна по умолчанию метка null и любые необработанные случаи?
Если он равен нулю, он попадет по умолчанию.
public enum YesNo
{
Yes,
No,
}
public class Program
{
public static void Main(string[] args)
{
YesNo? value = null;
switch (value)
{
case YesNo.Yes:
Console.WriteLine("Yes");
break;
case YesNo.No:
Console.WriteLine("No");
break;
default:
Console.WriteLine("default");
break;
}
}
}
Программа напечатает default
.
Если не обрабатывается значение null.
public class Program
{
public static void Main(string[] args)
{
YesNo? value = null;
switch (value)
{
case YesNo.Yes:
Console.WriteLine("Yes");
break;
case YesNo.No:
Console.WriteLine("No");
break;
case null:
Console.WriteLine("NULL");
break;
default:
Console.WriteLine("default");
break;
}
}
}
выводит NULL
.
Если у вас есть необработанное значение перечисления, которое было добавлено позже:
public enum YesNo
{
Yes,
No,
FileNotFound,
}
public class Program
{
public static void Main(string[] args)
{
YesNo? value = YesNo.FileNotFound;
switch (value)
{
case YesNo.Yes:
Console.WriteLine("Yes");
break;
case YesNo.No:
Console.WriteLine("No");
break;
default:
Console.WriteLine("default");
break;
}
}
}
Он по-прежнему печатает default
.
Вы можете использовать оператор с нулевым коалесцированием ??
для маршрутизации значений null
на конкретную метку case, отличную от default
:
public static IEnumerable<String> AsStrings(this IEnumerable<Char[]> src)
{
Char[] rgch;
var e = src.GetEnumerator();
while (e.MoveNext())
{
switch ((rgch = e.Current)?.Length ?? -1)
{
case -1: // <-- value when e.Current is 'null'
yield return null;
break;
case 0:
yield return String.Empty;
break;
case 1:
yield return String.Intern(new String(rgch[0], 1));
break;
default: // 2...n
yield return new String(rgch);
break;
}
}
}
Стоит отметить, что в С# 8.0 появился новый шаблон свойств для выражения switch. Теперь вы можете реализовать логику по умолчанию для переключения с помощью floor:
public double Calculate(int left, int right, Operator op) =>
op switch
{
Operator.PLUS => left + right,
Operator.MINUS => left - right,
Operator.MULTIPLY => left * right,
Operator.DIVIDE => left / right,
_ => 0 // default
}
Ref. https://docs.microsoft.com/en-us/dotnet/csharp/whats-new/csharp-8