169 похожих чатов

Всем привет. Я тут работаю над портом DiffUtil в .NET.

Будет работать как ObservableCollection. Быстро и без гемороя.

Вопрос. Будет ли это вам интересно и на сколько часто вам приходиться синхронизировать новую коллекцию со старой в ваших проектах?

15 ответов

27 просмотров

Топ штука вообще-то, частенько нужно

звучит, как да-я-сам-такой-велосипед-напишу, но по факту, конечно, интересно

Kirill
Уже написал)

в смысле да-я-сам - это про себя 🙂

Kirill- Автор вопроса
entdark
в смысле да-я-сам - это про себя 🙂

Я пробовал, тот еще геморой. Особенно когда список должен динамически меняться.

Можно взять Heckel со свифта. Скорее всего проще будет и быстрее переписать

Kirill- Автор вопроса
Kirill
Я пробовал, тот еще геморой. Особенно когда список...

а это универсальное решение с таргетом .NET Standrd?

Kirill- Автор вопроса
entdark
а это универсальное решение с таргетом .NET Standr...

Да, полностью. С конкретной версию пока не уверен, но думаю большенство старых .net планформ будут поддерживаться

Да, было бы очень интересно. Мне для синхронизации коллекций хватало ObservableCollection, но вариант с DiffUtil конечно кажется более гибким. Кстати знаю либу, которая что-то похожее делает, решая задачу наибольшей общей подпоследовательности: https://github.com/praeclarum/ListDiff Может пригодится) Тегните меня, пожалуйста, как выложите

Kirill- Автор вопроса
Vadim Sedov
Да, было бы очень интересно. Мне для синхронизации...

Спасибо за ссылку, интересная библиотека. Раньше ее не находил. Единственный момент, она не поддерживает перемещения 🙂

Kirill
Спасибо за ссылку, интересная библиотека. Раньше е...

А ваш вариант, кстати, возвращает IEnumerable и внутри себя делает yield continue/return?

Kirill- Автор вопроса
entdark
А ваш вариант, кстати, возвращает IEnumerable и вн...

Думал над этим. Конечно хочу именно так и сделать, для оптимизациии. Но там суть в том, что некоторые события могут отправляться пачками. На пример если добавили 10 элементов, то CollectionChanged будет вызван всего 1 раз. То есть все шаги считаются сразу. Но я уверен, и из этой ситуации можно найти выход и оптимизировать все под yield

Kirill- Автор вопроса
Vadim Sedov
Да, было бы очень интересно. Мне для синхронизации...

Проверил библиотеки. Моя либа на 10% быстрее без поиска перемещений и на 10% медленней с поиском перемещений 🙂 Ну и еще ListDiff не умеет обьеденять одинаковые операции в пачки 🙂

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта