No C # 8, deve-se marcar explicitamente os tipos de referência como nulos.
Por padrão, esses tipos não são capazes de conter nulos, um pouco semelhantes aos tipos de valor. Embora isso não mude o funcionamento das coisas, o verificador de tipos exigirá que você faça isso manualmente.
O código fornecido é refatorado para funcionar com o C # 8, mas não se beneficia desse novo recurso.
public static Delegate? Combine(params Delegate?[]? delegates)
{
// ...[]? delegates - is not null-safe, so check for null and emptiness
if (delegates == null || delegates.Length == 0)
return null;
// Delegate? d - is not null-safe too
Delegate? d = delegates[0];
for (int i = 1; i < delegates.Length; i++)
d = Combine(d, delegates[i]);
return d;
}
Aqui está um exemplo de um código atualizado (não funcionando, apenas uma idéia) aproveitando esse recurso. Ele nos salvou de uma verificação nula e simplificou um pouco esse método.
public static Delegate? Combine(params Delegate[] delegates)
{
// `...[] delegates` - is null-safe, so just check if array is empty
if (delegates.Length == 0) return null;
// `d` - is null-safe too, since we know for sure `delegates` is both not null and not empty
Delegate d = delegates[0];
for (int i = 1; i < delegates.Length; i++)
// then here is a problem if `Combine` returns nullable
// probably, we can add some null-checks here OR mark `d` as nullable
d = Combine(d, delegates[i]);
return d;
}