|
Как лучше всего сериализовать статическую коллекцию?
|
|||
---|---|---|---|
#18+
Есть статическая коллекция Код: c# 1. 2. 3. 4. 5. 6. 7. 8. 9.
Как лучше всего сериализовать коллекцию DefaultProfiles? Я читал, что сериализовать можно только нестатические и не рид-онли члены. Т. е. чтобы сериализовать DefaultProfiles, мне нужно сделать свойство-копию этого статического свойства, но уже не статическое и не рид-онли. Но мне ещё надо, чтобы каждый экземпляр Profile имел только одну копию DefaultProfiles. Попытался сделать так Код: c# 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15.
но ещё не проверял. Как считаете, будет работать? Тут расчёт на то, что копия DefaultProfiles будет создаваться только при сериализации, поэтому просто экземпляры Profile иметь каждый свою копию DefaultProfiles не будут, а будут ссылаться на один и тот же экземпляр. Верно я рассуждаю? ... |
|||
:
Нравится:
Не нравится:
|
|||
08.07.2016, 20:10 |
|
Как лучше всего сериализовать статическую коллекцию?
|
|||
---|---|---|---|
#18+
MineRunner, Что в итоге хочешь получить то? ... |
|||
:
Нравится:
Не нравится:
|
|||
08.07.2016, 20:47 |
|
Как лучше всего сериализовать статическую коллекцию?
|
|||
---|---|---|---|
#18+
ЕвгенийВMineRunner, Что в итоге хочешь получить то? 1. Хочу сериализовать DefaultProfiles. 2. Хочу получить в десериализованной копии такую же статическую штуку DefaultProfiles. 3. Хочу иметь только одну копию DefaultProfiles на все экземпляры Profile в пределах одного приложения. Т. е. после десериализации в, например, другом AppDomain, можно иметь другую копию DefaultProfiles. ... |
|||
:
Нравится:
Не нравится:
|
|||
08.07.2016, 20:55 |
|
Как лучше всего сериализовать статическую коллекцию?
|
|||
---|---|---|---|
#18+
сделай коллекцию синглтон ... |
|||
:
Нравится:
Не нравится:
|
|||
08.07.2016, 21:23 |
|
Как лучше всего сериализовать статическую коллекцию?
|
|||
---|---|---|---|
#18+
Вообще не понимаю смысла серилизации, если только не работа череp WCF ... |
|||
:
Нравится:
Не нравится:
|
|||
08.07.2016, 22:45 |
|
Как лучше всего сериализовать статическую коллекцию?
|
|||
---|---|---|---|
#18+
Иммануил Кантсделай коллекцию синглтон А у меня что? Cat2Вообще не понимаю смысла серилизации, если только не работа череp WCF Как раз работа через WCF. Я специально не конкретизирую, чтобы абстрагироваться. ... |
|||
:
Нравится:
Не нравится:
|
|||
09.07.2016, 03:45 |
|
Как лучше всего сериализовать статическую коллекцию?
|
|||
---|---|---|---|
#18+
Может, я туплю, но у меня такое ощущение, что я делаю что-то ненужное. Чтобы десериализовать объект в приложении А, это приложение А должно иметь ссылку на класс Profile, так? Тогда у него уже есть набор DefaultProfiles и при этом точно такой же, как и у того приложения Б, которое передаёт сериализованный объект приложению А, так? Т. е. сериализовать статическую константу DefaultProfiles в моём случае не нужно. Вот если бы приложение А не имело ссылки на класс Profile и не знало бы о его внутренней структуре, а получало бы просто данные в том виде, в который я сериализую объекты (xml там, или json), то имело бы смысл создавать дублирующее свойство, которое бы превращало static readonly в какое-нибудь обычное свойство, которое можно сериализовать. Правильно я рассуждаю? ... |
|||
:
Нравится:
Не нравится:
|
|||
09.07.2016, 04:10 |
|
Как лучше всего сериализовать статическую коллекцию?
|
|||
---|---|---|---|
#18+
MineRunnerВот если бы приложение А не имело ссылки на класс Profile и не знало бы о его внутренней структуре, а получало бы просто данные в том виде, в который я сериализую объекты (xml там, или json), то имело бы смысл создавать дублирующее свойство, которое бы превращало static readonly в какое-нибудь обычное свойство, которое можно сериализовать. Правильно я рассуждаю? Ну и вдобавок к этому, если я хочу, чтобы при добавлении DefaultProfilesToSerialize как дублирующего свойства для DefaultProfiles обычные инстансы класса Profile ссылались на ту же самую коллекцию дефолтных профайлов, то имеет смысл сделать свойство DefaultProfilesToSerialize без поля поддержки (backing field) - а просто чтобы это свойство возвращало ту же коллекцию DefaultProfiles. Так? Тогда мне надо переписать её без интерфейса - на конкретную коллекцию: Код: c# 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15.
... |
|||
:
Нравится:
Не нравится:
|
|||
09.07.2016, 04:15 |
|
Как лучше всего сериализовать статическую коллекцию?
|
|||
---|---|---|---|
#18+
Я правильно всё сделал? ... |
|||
:
Нравится:
Не нравится:
|
|||
09.07.2016, 04:16 |
|
Как лучше всего сериализовать статическую коллекцию?
|
|||
---|---|---|---|
#18+
MineRunnerЯ правильно всё сделал? Про цели не говориш ... |
|||
:
Нравится:
Не нравится:
|
|||
09.07.2016, 07:25 |
|
Как лучше всего сериализовать статическую коллекцию?
|
|||
---|---|---|---|
#18+
MineRunnerКак раз работа через WCF. Я специально не конкретизирую, чтобы абстрагироваться. Конкретизируйте хотя бы во что сериализовать: Binary, JSON, SOAP, XML, ProtoBuf, в сообщение для какой-нибудь очереди? ... |
|||
:
Нравится:
Не нравится:
|
|||
09.07.2016, 11:05 |
|
Как лучше всего сериализовать статическую коллекцию?
|
|||
---|---|---|---|
#18+
MineRunner, а что вообще такое DefaultProfiles и почему определено как статическое поле у Profile ? ... |
|||
:
Нравится:
Не нравится:
|
|||
09.07.2016, 11:11 |
|
Как лучше всего сериализовать статическую коллекцию?
|
|||
---|---|---|---|
#18+
P.S.: ну и сеттер надо добавить для DefaultProfilesToSerialize. Потому как read only свойства не сериализуются. ... |
|||
:
Нравится:
Не нравится:
|
|||
09.07.2016, 11:22 |
|
Как лучше всего сериализовать статическую коллекцию?
|
|||
---|---|---|---|
#18+
MineRunner, ну допустим статик можно обойти через iserializable ну допустим только чтение можно можно обойти через приватное прокси свойство в гетдатаобджект и конструкторе сериализации ну предположим можно обмануть рекурсию ну что вы будете делать со своей бедой в многопоточном исполнении, когда один поток работает с вашим листом а другой поток в десериализаторе чистит лист и хуячит дуда профили с диска? Ну и возникает вопрос - если кто - то снаружи имеет ссылку на профиль в листе а вы через десериализатор расхуячили этот лист и запихнули туда левые профили, что делать этому бедному существу снаружи с его ссылкой? ... |
|||
:
Нравится:
Не нравится:
|
|||
09.07.2016, 12:52 |
|
Как лучше всего сериализовать статическую коллекцию?
|
|||
---|---|---|---|
#18+
Где-то в степиMineRunner, ну допустим статик можно обойти через iserializable ну допустим только чтение можно можно обойти через приватное прокси свойство в гетдатаобджект и конструкторе сериализации ну предположим можно обмануть рекурсию Ой зря Вы ему об этом написали :) ... |
|||
:
Нравится:
Не нравится:
|
|||
09.07.2016, 12:59 |
|
Как лучше всего сериализовать статическую коллекцию?
|
|||
---|---|---|---|
#18+
skyANA, да пускай учится, берет учебник читает про инкапсуляцию, открытое поле для чтения и аксессор к этому полю снаружи выносит мозг не по детский. тем более инициализированное нулем гыгы, а мутатор ( типа set) ему студия не дала поставить ))))) ... |
|||
:
Нравится:
Не нравится:
|
|||
09.07.2016, 13:06 |
|
Как лучше всего сериализовать статическую коллекцию?
|
|||
---|---|---|---|
#18+
skyANAMineRunnerКак раз работа через WCF. Я специально не конкретизирую, чтобы абстрагироваться. Конкретизируйте хотя бы во что сериализовать: Binary, JSON, SOAP, XML, ProtoBuf, в сообщение для какой-нибудь очереди? А в чём будет принципиальное различие, если я для разных этих вещей сериализую? Пусть будет сериализация XML. Забудьте про WCF (это я зря приплёл). skyANAMineRunner, а что вообще такое DefaultProfiles и почему определено как статическое поле у Profile ? Про профили я просто так придумал. Тут главное суть - есть некие дефолтные наборы настроек. Я запихал их в константную статику, по типу String.Empty. Почему String.Empty находится в классе String? Потому что String.Empty связано с этим классом вне зависимости от контекста использования, поэтому в любом контексте, где используется String, должна быть возможность и использовать String.Empty. Поэтому удобно запихать String.Empty прямо в String. Вот по аналогии и я свои дефолтные профили запихал в класс профиля. ... |
|||
:
Нравится:
Не нравится:
|
|||
09.07.2016, 19:10 |
|
Как лучше всего сериализовать статическую коллекцию?
|
|||
---|---|---|---|
#18+
skyANAP.S.: ну и сеттер надо добавить для DefaultProfilesToSerialize. Потому как read only свойства не сериализуются. Вот, это уже по существу советы. 1. Но, как я понял, и пояснил это тут , если надо потом сделать десериализацию в тот же класс Profile, то у приёмника сериализованного Profile должна быть ссылка на определение класса. А раз так, то DefaultProfiles он получает и так, без специальной сериализации/десериализации этого static readonly свойства. Так? 2. А вот если приёмник получает некий XML (JSON и т. д. по вкусу) и не собирается десериализовать его в объект Profile, то у этого приймника, скорее всего, нет ссылки на класс Profile и, соответственно, он не может получить набор DefaultProfiles в виде static readonly. Поэтому такому приёмнику надо специально сделать свойство в Profile, в котором можно разместить DefaultProfiles при сериализации. Так? 3. Но есть ещё требование, чтобы инстансы класса Profile не создавали каждый раз по копии DefaultProfiles. Теперь как это всё реализовать? Вот вы сказали, нужно сеттер добавить. А что и куда он будет присваивать, с учётом вот этих моих трёх требований? Если бэкинг филд, то это копия DefaultProfiles на каждый инстанс Profile. Так? ... |
|||
:
Нравится:
Не нравится:
|
|||
09.07.2016, 19:18 |
|
Как лучше всего сериализовать статическую коллекцию?
|
|||
---|---|---|---|
#18+
Где-то в степину что вы будете делать со своей бедой в многопоточном исполнении, когда один поток работает с вашим листом а другой поток в десериализаторе чистит лист и хуячит дуда профили с диска? Ну и возникает вопрос - если кто - то снаружи имеет ссылку на профиль в листе а вы через десериализатор расхуячили этот лист и запихнули туда левые профили, что делать этому бедному существу снаружи с его ссылкой? Пишу в комментах к классу - потоконебезопасен. Но вообще, всё проще - приложение один раз получает настройки и DefaultProfiles чисто для удобства - чтобы можно было выбрать готовые пресеты, а не прожимать кучу кнопок каждый раз. Смысла менять список профилей мало (юзер пока не может добавлять свои профили, а либо использует готовые, либо прожимает настройки каждый раз заново), а уж в многопотоке - вообще нет. Просто дефолтные профили покрывают почти все кейсы юзера и особого смысла менять их нет. Если поменяет, то не в самом списке DefaultProfiles, а только в некотором CurrentProfile, которым может быть один из первоначально выбранных DefaultProfiles. Как-то так. Я ещё раз говорю, что специально абстрагируюсь от конкретного контекста, а стараюсь задать вопрос про некоторую сериализацию статика в вакууме. ... |
|||
:
Нравится:
Не нравится:
|
|||
09.07.2016, 19:24 |
|
Как лучше всего сериализовать статическую коллекцию?
|
|||
---|---|---|---|
#18+
Где-то в степиMineRunner, ну допустим статик можно обойти через iserializable ну допустим только чтение можно можно обойти через приватное прокси свойство в гетдатаобджект и конструкторе сериализации ну предположим можно обмануть рекурсию ну что вы будете делать со своей бедой в многопоточном исполнении, когда один поток работает с вашим листом а другой поток в десериализаторе чистит лист и хуячит дуда профили с диска? Ну и возникает вопрос - если кто - то снаружи имеет ссылку на профиль в листе а вы через десериализатор расхуячили этот лист и запихнули туда левые профили, что делать этому бедному существу снаружи с его ссылкой? С каким моим листом? Профили находятся где-то в приложении - например, в классе Настройки. Я показываю юзеру настройки, где выбран текущий профиль и есть набор профилей, который включает набор дефолтных профилей (грубо говоря, сначала идёт набор дефолтных, а нище - текущие юзерск ие или юзерск ий ). DefaultProfiles нужны просто для удобства, чтобы наполнить список профилей некоторыми заранее заданными профилями. Если кто-то там в потоках "хуячит лист", то он это делает не с DefaultProfiles, а с неким листом в настройках. Не знаю, как ещё сказать. Пусть будет так: Profile служит просто контейнером для набора DefaultProfiles, поскольку DefaultProfiles связаны с Profile по смыслу. Наподобие того, как я объяснил про String.Empty. ... |
|||
:
Нравится:
Не нравится:
|
|||
09.07.2016, 19:34 |
|
Как лучше всего сериализовать статическую коллекцию?
|
|||
---|---|---|---|
#18+
Но для полной красоты надо ещё сделать все профили в DefaultProfiles readonly, чтобы их нельзя было менять в самом списке DefaultProfiles. Как, кстати, это можно сделать? ... |
|||
:
Нравится:
Не нравится:
|
|||
09.07.2016, 19:39 |
|
Как лучше всего сериализовать статическую коллекцию?
|
|||
---|---|---|---|
#18+
MineRunnerНо для полной красоты надо ещё сделать все профили в DefaultProfiles readonly, чтобы их нельзя было менять в самом списке DefaultProfiles. Как, кстати, это можно сделать? Наверное, закрыть DefaultProfiles и сделать публичный метод - GetDefaultProfiles, так? ... |
|||
:
Нравится:
Не нравится:
|
|||
09.07.2016, 19:40 |
|
Как лучше всего сериализовать статическую коллекцию?
|
|||
---|---|---|---|
#18+
MineRunnerMineRunnerНо для полной красоты надо ещё сделать все профили в DefaultProfiles readonly, чтобы их нельзя было менять в самом списке DefaultProfiles. Как, кстати, это можно сделать? Наверное, закрыть DefaultProfiles и сделать публичный метод - GetDefaultProfiles, так? Который будет каждый раз возвращать копию DefaultProfiles с копированными же объектами Profile в нём. Так? ... |
|||
:
Нравится:
Не нравится:
|
|||
09.07.2016, 19:41 |
|
Как лучше всего сериализовать статическую коллекцию?
|
|||
---|---|---|---|
#18+
MineRunnerMineRunnerпропущено... Наверное, закрыть DefaultProfiles и сделать публичный метод - GetDefaultProfiles, так? Который будет каждый раз возвращать копию DefaultProfiles с копированными же объектами Profile в нём. Так? Во! А чтобы не мучаться с копированием дефолтных профилей каждый раз при запросе GetDefaultProfiles, то лучше вообще создавать дефолтные профили прямо в этом методе - тогда он каждый раз будет возвращать профили с одними и теми же свойствами. Получается, вариант со static readonly DefaultProfiles плохой и лучше перейти на метод GetDefaultProfiles. Так? ... |
|||
:
Нравится:
Не нравится:
|
|||
09.07.2016, 19:44 |
|
Как лучше всего сериализовать статическую коллекцию?
|
|||
---|---|---|---|
#18+
MineRunnerMineRunnerпропущено... Который будет каждый раз возвращать копию DefaultProfiles с копированными же объектами Profile в нём. Так? Во! А чтобы не мучаться с копированием дефолтных профилей каждый раз при запросе GetDefaultProfiles, то лучше вообще создавать дефолтные профили прямо в этом методе - тогда он каждый раз будет возвращать профили с одними и теми же свойствами. Получается, вариант со static readonly DefaultProfiles плохой и лучше перейти на метод GetDefaultProfiles. Так? Это называется, кажется, фабрика, да? ... |
|||
:
Нравится:
Не нравится:
|
|||
09.07.2016, 19:45 |
|
|
start [/forum/topic.php?fid=20&fpage=58&tid=1400475]: |
0ms |
get settings: |
10ms |
get forum list: |
12ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
37ms |
get topic data: |
13ms |
get forum data: |
3ms |
get page messages: |
61ms |
get tp. blocked users: |
2ms |
others: | 14ms |
total: | 160ms |
0 / 0 |