Jest jeszcze jeden sposób na osiągnięcie tego wyniku, który jest dużo czystszy w użyciu, ale wymaga więcej kodu. Mój implementujący niestandardowy typ i konwerter typów jest możliwy następujący kod:
List<int> array = Settings.Default.Testing;
array.Add(new Random().Next(10000));
Settings.Default.Testing = array;
Settings.Default.Save();
Aby to osiągnąć, potrzebujesz typu z konwerterem typów, który umożliwia konwersję do iz ciągów. Robisz to, dekorując typ za pomocą TypeConverterAttribute:
[TypeConverter(typeof(MyNumberArrayConverter))]
public class MyNumberArray ...
Następnie implementujemy ten konwerter typu jako wyprowadzenie TypeConverter:
class MyNumberArrayConverter : TypeConverter
{
public override bool CanConvertTo(ITypeDescriptorContext ctx, Type type)
{ return (type == typeof(string)); }
public override bool CanConvertFrom(ITypeDescriptorContext ctx, Type type)
{ return (type == typeof(string)); }
public override object ConvertTo(ITypeDescriptorContext ctx, CultureInfo ci, object value, Type type)
{
MyNumberArray arr = value as MyNumberArray;
StringBuilder sb = new StringBuilder();
foreach (int i in arr)
sb.Append(i).Append(',');
return sb.ToString(0, Math.Max(0, sb.Length - 1));
}
public override object ConvertFrom(ITypeDescriptorContext ctx, CultureInfo ci, object data)
{
List<int> arr = new List<int>();
if (data != null)
{
foreach (string txt in data.ToString().Split(','))
arr.Add(int.Parse(txt));
}
return new MyNumberArray(arr);
}
}
Zapewniając kilka wygodnych metod w klasie MyNumberArray, którą możemy następnie bezpiecznie przypisać do iz listy, cała klasa wyglądałaby mniej więcej tak:
[TypeConverter(typeof(MyNumberArrayConverter))]
public class MyNumberArray : IEnumerable<int>
{
List<int> _values;
public MyNumberArray() { _values = new List<int>(); }
public MyNumberArray(IEnumerable<int> values) { _values = new List<int>(values); }
public static implicit operator List<int>(MyNumberArray arr)
{ return new List<int>(arr._values); }
public static implicit operator MyNumberArray(List<int> values)
{ return new MyNumberArray(values); }
public IEnumerator<int> GetEnumerator()
{ return _values.GetEnumerator(); }
IEnumerator IEnumerable.GetEnumerator()
{ return ((IEnumerable)_values).GetEnumerator(); }
}
Na koniec, aby użyć tego w ustawieniach, dodajesz powyższe klasy do zestawu i kompilujesz. W edytorze Settings.settings wystarczy kliknąć opcję „Browse”, wybrać klasę MyNumberArray i gotowe.
Znowu jest to dużo więcej kodu; Jednak można go zastosować do znacznie bardziej skomplikowanych typów danych niż prosta tablica.