У меня есть объект:
public class BindObjectToFile
{
public int Property1 {get; set;}
public int Property2 {get; set;}
public BindObjectToFile(string BindingFilePath)
{
...
}
}
У меня есть Json файл:
{
"Property1" : 1,
"Property2" : 2,
}
Всякий раз, когда свойство объекта Изменения, я хочу, чтобы Json Файл изменился вместе с ним.
Всякий раз, когда свойство в JsonFile Изменения, я хочу Объект для изменения вместе с ним.
Я бы хотел, чтобы все дочерние элементы BindObjectToFile легко наследовали эту функциональность, не требуя корректировки для методов получения / установки их свойств. ,
По существу , Я хочу, чтобы объект ощущался так, как будто он хранится в файле, а не в памяти.
Что я попробовал:
- Я начал (тупо) Сериализация / десериализация всего объекта на каждом получателе / установщике объекта:
internal int _property1;
public int Property1
{
get
{
return JsonConvert.DeserializeObject<ObjectToFile>(File.ReadAllText(JsonFilePath))._property1;
}
set
{
_property1 = value;
File.WriteAllText(JsonFilePath, JsonConvert.SerializeObject(this));
}
}
Newtonsoft. json замечательно, но этот подход кажется неправильным, потому что он заставляет меня переписывать всю эту стандартную таблицу для каждого свойства каждого нового дочернего элемента, не сообщая никому, что именно так должен предполагаться мой класс BindObjectToFile использоваться.
Далее я попытался реализовать INotifyPropertyChanged
, чтобы сохранить только что сериализованный объект только при изменении свойства. Это было немного лучше, но все равно не учитываются ситуации, когда файл изменяется чем-то другим, кроме этого экземпляра 'BindObjectToFile'.
Я пытался создать Generi c BindObjectToFile, который также реализовал INotifyPropertyChanged. Я сделал это в надежде, что с помощью объекта Generi c я смогу обойти эту проблему без использования наследования, чтобы мне не пришлось искать способ заставить детей писать сумасшедшие методы получения / установки для каждого из их свойств. :
public abstract class ObjectToFile<T> : INotifyPropertyChanged
{
public T _value;
public T Value
{
get
{
return JsonConvert.DeserializeObject<T>(File.ReadAllText(Path));
}
set
{
_value = value;
File.WriteAllText(Path, JsonConvert.SerializeObject(_value ));
}
}
public string JsonFilePath;
public ObjectToFile(T value, string path)
{
_value = value;
JsonFilePath = path;
}
}
Но это все равно заставляет меня инициировать или управлять событиями PropertyChange в дочерних классах при изменении их свойств.
И я не хочу чтобы сделать что-то из этого - я просто хочу родительский класс для решения проблемы, чтобы я мог счастливо создавать дочерние классы, которые ведут себя правильно, и мне не нужно думать об этом.
Это кажется разумным, верно ?
Предостережения:
- Я не против переписывать / перечитывать весь файл каждый раз при обращении к свойству или при его изменении.
- В моем контексте я не не волнует скорость. Если кто-то еще откроет один из этих файлов, и мне придется подождать несколько сотен мсек для своей очереди, это не проблема.
- Все объекты, с которыми я работаю, предельно просты и содержат свойства с основными c типы данных.
- Все объекты, с которыми я работаю, чрезвычайно малы и редко имеют более пяти или шести свойств.
Спасибо, всем!