C # 6 додає нову функцію саме для цього: розширення Додати методи. Це завжди було можливим для VB.net, але тепер він доступний на C #.
Тепер вам не потрібно додавати Add()
методи до своїх класів безпосередньо, ви можете реалізувати їх як методи розширення. Розширюючи будь-який перелічений тип Add()
методом, ви зможете використовувати його у виразах ініціалізатора колекції. Таким чином, вам більше не доведеться виводити зі списків прямо ( як це було сказано в іншій відповіді ), ви можете просто розширити його.
public static class TupleListExtensions
{
public static void Add<T1, T2>(this IList<Tuple<T1, T2>> list,
T1 item1, T2 item2)
{
list.Add(Tuple.Create(item1, item2));
}
public static void Add<T1, T2, T3>(this IList<Tuple<T1, T2, T3>> list,
T1 item1, T2 item2, T3 item3)
{
list.Add(Tuple.Create(item1, item2, item3));
}
// and so on...
}
Це дозволить зробити це в будь-якому класі, який реалізує IList<>
:
var numbers = new List<Tuple<int, string>>
{
{ 1, "one" },
{ 2, "two" },
{ 3, "three" },
{ 4, "four" },
{ 5, "five" },
};
var points = new ObservableCollection<Tuple<double, double, double>>
{
{ 0, 0, 0 },
{ 1, 2, 3 },
{ -4, -2, 42 },
};
Звичайно, ви не обмежуєтеся розширенням колекцій кортежів, це може бути колекція будь-якого конкретного типу, для якого потрібен спеціальний синтаксис.
public static class BigIntegerListExtensions
{
public static void Add(this IList<BigInteger> list,
params byte[] value)
{
list.Add(new BigInteger(value));
}
public static void Add(this IList<BigInteger> list,
string value)
{
list.Add(BigInteger.Parse(value));
}
}
var bigNumbers = new List<BigInteger>
{
new BigInteger(1), // constructor BigInteger(int)
2222222222L, // implicit operator BigInteger(long)
3333333333UL, // implicit operator BigInteger(ulong)
{ 4, 4, 4, 4, 4, 4, 4, 4 }, // extension Add(byte[])
"55555555555555555555555555555555555555", // extension Add(string)
};
C # 7 додасть до підтримки кортежі, вбудовані в мову, хоча вони будуть іншого типу ( System.ValueTuple
замість цього). Тож було б добре додати перевантаження для кортежів цінності, щоб у вас була можливість використовувати їх також. На жаль, між ними не визначено неявних перетворень.
public static class ValueTupleListExtensions
{
public static void Add<T1, T2>(this IList<Tuple<T1, T2>> list,
ValueTuple<T1, T2> item) => list.Add(item.ToTuple());
}
Таким чином, ініціалізація списку буде виглядати ще приємніше.
var points = new List<Tuple<int, int, int>>
{
(0, 0, 0),
(1, 2, 3),
(-1, 12, -73),
};
Але замість того, щоб переживати всю цю неприємність, може бути просто краще перейти до використання ValueTuple
виключно.
var points = new List<(int, int, int)>
{
(0, 0, 0),
(1, 2, 3),
(-1, 12, -73),
};