Donnée:
class Program
{
private static readonly List<(int a, int b, int c)> Map = new List<(int a, int b, int c)>()
{
(1, 1, 2),
(1, 2, 3),
(2, 2, 4)
};
static void Main(string[] args)
{
var result = Map.FirstOrDefault(w => w.a == 4 && w.b == 4);
if (result == null)
Console.WriteLine("Not found");
else
Console.WriteLine("Found");
}
}
Dans l'exemple ci-dessus, un compilateur erreur s'est produite à la ligne if (result == null)
.
CS0019 Opérateur '==' ne peut pas être appliquée à des opérandes de type '(int a, int b, int c) " et "
Comment puis-je vérifier que le n-uplet est trouvé avant de procéder à mon "trouvé" la logique?
Avant d'utiliser le c# 7 tuples, je voudrais avoir ceci:
class Program
{
private static readonly List<Tuple<int, int, int>> Map = new List<Tuple<int, int, int>>()
{
new Tuple<int, int, int> (1, 1, 2),
new Tuple<int, int, int> (1, 2, 3),
new Tuple<int, int, int> (2, 2, 4)
};
static void Main(string[] args)
{
var result = Map.FirstOrDefault(w => w.Item1 == 4 && w.Item2 == 4);
if (result == null)
Console.WriteLine("Not found");
else
Console.WriteLine("Found");
}
}
Qui a bien fonctionné. J'aime le plus facilement interprété l'intention de la nouvelle syntaxe, mais je suis incertain sur la façon de nulle vérifier avant d'agir sur ce qui a été trouvé (ou pas).