Как-то раз в одном чате прозвучала идея сравнить разные технологии для написания оконных приложений. В частности, под Windows. Используя средства языка C#. То есть, конечно, можно это сделать и с помощью C++, Python, Rust, JS и других языков, но мы же шарписты, нам интереснее именно то, что мы можем сами использовать, не меняя язык программирования.
Итак, оконные приложения на C#. Их можно написать, используя:
Windows Forms
WPF
WinUI
.NET MAUI
Avalonia
Uno Platform
Такое многообразие фреймворков обусловлено тем, что язык развивался, менялись подходы, совершенствовались технологии. А в какой-то момент к разработке подключились сторонние разработчики и к средствам Microsoft добавились Avalonia и Uno.
Таким образом, для того чтобы начать писать оконные приложения надо решить, используя какую технологию использовать. Но, кроме того, неплохо бы понимать, где будет приложение использоваться – только на Windows или есть необходимость в запуске на MacOS и Linux. А может быть еще и на IOS и Android?
В общем, в этой статье попробуем разобраться в возможностях этих фреймворков и сравним их. Сравнивать будем по таким критериям:
Платформы, в которых можно запустить приложение
Сложность разработки
Потребляемые ресурсы
Скорость запуска
Для корректности сравнения будем использовать одну логику для всех приложений. Более того, попытаемся сделать их максимально похожими друг на друга.
Часть 1. Логика
Итак, чтобы не сравнивать пустые приложения без какой-либо функциональности, и при этом не перегружать излишним наполнением, реализовал простейшую версию игры Крестики-Нолики. Логика самой игры простая: есть два игрока Х и О. Начинает игрок Х потом ходит О. Кто первым соберет три своих символа в ряд — выигрывает, если после последнего хода победителя нет, то ничья. Игра осуществляется с одного устройства, по очереди.
Весь код логики практически один в один переходит из приложения в приложение, за исключением некоторых особенностей в разных фреймворках. Например, в Авалонии нет встроенного механизма отображения всплывающих окон (Message Box) и для того, чтобы он появился надо установить дополнительный пакет. Не сложно, но нюанс. В некоторых фреймворках нельзя напрямую посчитать кнопки из интерфейса и надо придумывать обходные пути.
Важно также отметить, что везде, кроме WinForms по-хорошему следует использовать паттерн MVVM, однако для простейшего приложения заморачиваться не стал и работает все напрямую.
Часть 2. Пользовательский интерфейс
Разработка UI в приложениях C# отличается не очень сильно друг от друга. Выделяется разве что WinForms, где элементы интерфейса размещаются обычно вручную в графическом редакторе, что в свою очередь весьма дружелюбно по отношению к людям без опыта.
Еще можно размещать элементы вручную в WPF, однако рекомендуется все же выстраивать интерфейс вручную задавая параметры в коде страницы.
Осложняет процесс разработки внешнего вида отсутствие интерактивного отображения получаемого результата в MAUI и WinUI – там посмотреть на результат можно только после сборки и запуска. Да, есть такая функция как Hot Reload, когда изменения будут появляться после горячей перезагрузки без перезапуска всего приложения, но тоже не без нюансов. Во-первых, при горячей перезагрузке теряется состояние приложения (если оно отдельно не сохраняется где-то), например при игре уже есть несколько крестиков и ноликов, то после Hot Reload они «забываются». Во-вторых, бывает, что изменения не отображаются и все равно приходится перезапускать приложение. Не баг, а фича, как говорится.
В целом же привыкнуть можно ко всему и даже потом возвращаться к WinForms становится тяжко – хочется все настраивать самому.
В конечном итоге интерфейс готовых приложений получился таким:
-
Windows Forms
WPF
WinUI
MAUI
-
Avalonia
-
Uno Platform
Я не сильно старался сделать их идентичными, потому что и задачи такой не было, да и на последующие измерения цвет кнопочек не повлияет. Более того, можно обратить внимание, что некоторые между собой похожи. Это результат применения в них компонентов WinUI. В MAUI дополнительно используются фирменные шрифты и MaterialDesign – поэтому кнопки со скругленными углами. А еще WinUI подтягивает основную тему из системы и поэтому все, кроме WinForms и WPF темные. Соответственно в первых двух нужно отдельно добавлять обработку светлой/темной темы.
Часть 3. Платформы
Тут мы подходим к глобальным возможностям всех фреймворков. Итак, таблица ниже показывает, под какие платформы может быть собрано приложение.
Фреймворки |
Windows |
MacOS |
Linux |
Android |
iOS |
WinForms |
+ |
||||
WPF |
+ |
||||
WinUI |
+ |
||||
.NET MAUI |
+ |
+ |
+ |
+ |
|
Avalonia |
+ |
+ |
+ |
+ |
+ |
Uno Platform |
+ |
+ |
+ |
+ |
+ |
Как видим, что вполне логично, все шесть фреймворков позволяют писать оконные приложения для Windows. Но есть и различия. Они кроются как в кроссплатформенности MAUI, Avalonia и Uno, так и в компонентах, которые используются для отрисовки графического интерфейса.
Углубляться сильно не будем в дебри, но стоит знать, что MAUI Авалония используют компоненты WinUI, Uno в свою очередь может реализовывать оконное приложение как в WPF варианте, так и WinUI. Это может быть полезно в отдельных случаях.
Кроме того, нативные фреймворки WinForms, WPF и WinUI отличаются технически:
- Windows Forms использует GDI+ для отрисовки интерфейса
- WPF использует DirectX для рендеринга
- WinUI использует для рендеринга DirectX/DirectComposition
Так же, есть различие в используемых компонентах, библиотеках и подходах. Иными словами, все технологии, представленные в статье, имеют множество различий при схожей функциональности даже в рамках одной целевой платформы.
Часть 4. Ресурсы и скорость запуска
Сейчас мы подошли к той части «исследования», когда в дело вступают цифры. В данной части посмотрим на то, сколько приложения занимают места в оперативной памяти. Сравнивать будем в двух режимах: в Visual Studio в режиме Debug и в диспетчере задач запущенное опубликованное приложение (конфигурация Release).
WinForms |
WPF |
WinUI |
.NET MAUI |
Avalonia |
Uno Platform |
|
Debug (Mb) |
15 |
80 |
80 |
132 |
82 |
62 |
Release (Mb) |
6,1 |
19,6 |
26,2 |
54,4 |
32,6 |
13,6 |
Эти значения получены из Visual Studio при запуске отладки каждого приложения по отдельности.
А вот релизную сборку я решил проверить более тщательно. Кроме того, стояла задача проверить скорость запуска каждого приложения. Понятно, что все они с такой мизерной функциональностью не должны загружаться долго, однако различия в скорости есть.
Для сбора данных я написал скрипт для PowerShell, который запускает приложение, ждет, когда оно загрузится (станет отзывчивым), дополнительно ждет пару секунд на случай неполной загрузки и выключает приложение. И так 100 раз подряд для каждого приложения. Попутно скрипт собирает данные об используемом объеме памяти и вычисляет скорость запуска.
В процессе тестов, обратил внимание, что некоторые приложения занимают значительный объем в памяти. Поискал информацию, с чем это может быть связано и нашел вариант, где ответственность возлагалась на запаздывающую сборку мусора. Сомнительно, но ок — добавил в скрипт принудительный вызов GC.
[Console]::OutputEncoding = [System.Text.Encoding]::UTF8
$apps = @(
"PATH_TO_TicTacToeUno.exe",
"PATH_TO_TicTacToeMAUIApp.exe",
"PATH_TO_TicTacToeWPF.exe",
"PATH_TO_TicTacToeAvalonia.Desktop.exe",
"PATH_TO_TicTacToeWinUI.exe",
"PATH_TO_TicTacToeWinForms.exe"
)
$results = @{}
foreach ($app in $apps) {
$appName = [System.IO.Path]::GetFileNameWithoutExtension($app)
$times = @()
$memoryUsages = @()
for ($i = 1; $i -le 100; $i++) {
Write-Host "Starting $appName (Iteration $i of 100)..."
$start = Get-Date
$process = Start-Process $app -PassThru
# Ждем, пока главное окно приложения не станет отзывчивым
while (-not $process.MainWindowHandle) {
Start-Sleep -Milliseconds 100
}
$end = Get-Date
$duration = ($end - $start).TotalSeconds
$times += $duration
# Измеряем использование памяти
Start-Sleep -Seconds 2 # Даем приложению время полностью загрузиться
$memory = (Get-Process -Id $process.Id).PrivateMemorySize64 / 1MB
$memoryUsages += $memory
# Закрываем приложение
Stop-Process $process.Id -Force
while (-not $process.HasExited) {
Start-Sleep -Milliseconds 100
}
# Освобождение ресурсов и сборка мусора
$process.Dispose()
[System.GC]::Collect()
[System.GC]::WaitForPendingFinalizers()
# Ждем немного перед следующим запуском
Start-Sleep -Seconds 5
}
$averageTime = ($times | Measure-Object -Average).Average
$averageMemory = ($memoryUsages | Measure-Object -Average).Average
$results[$appName] = @{
Time = $averageTime
Memory = $averageMemory
}
}
# Вывод результатов
Write-Host "`nResults after 100 launches:"
$results.GetEnumerator() | Sort-Object {$_.Value.Time} | ForEach-Object {
Write-Host ("{0,-30} : StartUp Time: {1:N3} seconds, Memory Usage: {2:N2} Mb" -f $_.Key, $_.Value.Time, $_.Value.Memory)
}
Дополнительно отмечу, что скрипт я запускал по несколько раз с некоторыми изменениями, в частности брал данные о памяти как из process.WorkingSet64 так и process.PrivateMemorySize64, а так же для подстраховки продублировал тесты в Python-скрипте. Суммарно вышло что-то около 500-600 запусков каждого приложения, что в общем дает вполне понятную картину.
Еще, прежде чем показать результаты, оговорюсь относительно WinUI приложения — оно доставило больше всех хлопот, как ни странно, поскольку запускалось уверенно в VS и даже тесты проходили в уже готовом и установленном приложении, однако по факту не запускалось. Ошибка с Windows.ui.xaml.dll вызываемая непонятно по какой причине, не давала мне покоя несколько дней. Несколько тестов были проведены с этой “особенностью”. Тем не менее глобально, после того, как проблема была решена, ничего в цифрах не поменялось кардинально.
Итак, ниже скриншоты из PowerShell:
1 запуск:
-
5 запусков
10 запусков:
100 запусков:
10 запусков на Python:
Результаты интересные. По скорости запуска различия есть, но по сути на уровне погрешности — все запускаются быстро. Причем, когда наблюдаешь вживую за процессом выполнения скрипта, заметно, что первые 3-5 раз загрузка UI происходит дольше, чем последующие. Связано это с кэшированием на уровне ОС. Правда актуально это для ClickOnce-сборок в большей степени, но заметно и на WInUI, которую запускал без установки.
Гораздо интереснее ситуация с памятью. Тут и явный лидер — неожиданно - Uno Platform, и явный аутсайдер - WPF.
Самый последний тест, при котором все уже работало и не падало - 100 итераций в PowerShell. Там же и минимальное значение задействованных ресурсов - в среднем 1,46 Мб. Тоже, скорее всего, связано с каким-то кэшированием, потому что в других тестах стабильно требовал ~ 8Мб.
Но всегда, во всех тестах, больше всего памяти отъедал WPF. Скорее всего это связано с тем, что учитываются “общие ресурсы” используемые другими приложениями в это же время в системе. По-крайней мере именно из-за этого вносил изменение в скрипт для получения данных из PrivateMemorySize64, однако тесты показали, что разницы нет. Возможна ли тут ошибка? Да, вполне может быть. Но и Python-скрипт показал такие же данные, поэтому я склоняюсь все же к тому, что WPF действительно самый ресурсоемкий фреймворк.
Но я предполагал, что им окажется MAUI. И по используемым ресурсам, MAUI лишь WPF уступил в объеме задействованной памяти. В это же время, скорость запуска во всех тестах у MAUI была самой низкой.
Часть 5. Сложность разработки
На самом деле, оценить сложность разработки в каждом конкретном фреймворке нельзя. Когда он, фреймворк, для тебя новый — сложно. Со временем становится сильно проще. Впрочем, как и в любом другом деле. Поэтому сказать однозначно, что в MAUI сложнее разрабатывать десктопное приложение, чем в WinUI, например, нельзя.
Но совершенно точно WinForms - самый простой из представленных фреймворков в освоении. Тому есть два объяснения — графический редактор (дизайнер) и отсутствие необходимости в использовании MVVM паттерна и бесконечного числа биндингов.
Но, опять же, все зависит от сложности проекта. В моем тестовом проекте везде было одинаково несложно. Даже с учетом того, что опыта с Uno и WinUI до последнего времени у меня не было.
Часть 6. Сборка и развертывание
Пару слов про то, насколько сложно подготовить проект к публикации и использовать его потом.
В целом, процесс должен быть не очень сложным везде. На практике, есть множество нюансов. В частности, неожиданно WinUI преподнес неприятные сюрпризы. Различных решений проблемы я нашел множество, но ни одно так и не помогло и, в конечном счете, запускал приложение для тестов из папки Release. Остальные приложения собрались и установились без проблем.
Дополнительно надо иметь в виду, что приложению требуется сертификат. То есть да, можно не подписывать приложение вовсе, но и распространять его будет сложнее - Windows на сторонних компьютерах будет ругаться при установке. Поэтому, хотя бы тестовым сертификатом подписать приложение стоит. А вот полноценный сертификат стоит денег, а в текущих условиях еще и надо найти, где его приобрести.
Конечно, это всё нюансы и наверно есть какие-то пути решения вопроса, да и вопрос сам не первоочередной важности. Но знать об этом стоит.
Часть 7. Итог
Что ж, стоит подвести итоги нашего небольшого исследования-сравнения. Для кого вообще оно делалось? Для тех, кто не занимался разработкой оконных приложений, но хотел бы понять, какие есть актуальные технологии. И вот эти технологии мы рассмотрели. Весьма поверхностно, конечно, но и задачи писать энциклопедию о том, как написать оконное приложение со всеми тонкостями, не стояло. А вот сделать вывод о том, с чего начать вкатываться в мир разработки приложений под Windows, а потом и других платформ, вполне можно.
Мое видение, основанное на имевшемся ранее и полученном сейчас такое:
- Начинать стоит все-таки с базы – с Windows Forms. Да, технология не нова, даже можно ее считать устаревшей. Но она живая и функциональная. Многие приемы на ней можно отработать, да и собрать действительно сложное приложение с графическим интерфейсом вполне реально. Да чего там – так делали, делали много и долго.
- Вторым шагом стоит изучить WPF. Эта технология позволит развить понимание паттерна MVVM, проектирование интерфейса в XAML и откроет путь к более современным стекам.
- Дальше путь открыт ко всему. Я был приятно удивлен возможностям Uno Platform, не ожидал. Кроме того, что можно написать приложение под любую актуальную ОС, в том числе и мобильную, так еще и весьма бережно эта технология относится, как оказалось, к ресурсам. Не то, чтобы это сильно критично, но, когда проект большой и нужно бороться за производительность, приложение, потребляющее меньше ресурсов будет выглядеть предпочтительнее на мой взгляд.
Еще из важного – возможность собрать дизайн приложения Uno в Figma и импортировать код интерфейса прямо в проект в виде XAML-кода! Такого нет ни у кого из других рассмотренных фреймворков.
И, напоследок, пару слов о размере приложения на диске.
Здесь в папках располагаются установщики. WinForms - ожидаемо, самое “легкое” приложение. MAUI - без комментариев. Хотя нет, уточню, что в сборке MAUI отсутствуют билды под другие платформы, то есть это именно Windows-приложение.
На этом все. Делайте свои выводы, пробуйте разрабатывать оконные приложения и успехов!
P.S. исходный код всех проектов доступен по ссылке: https://github.com/algmironov/WinAppFrameworksComparison
Комментарии (42)
kovserg
15.08.2024 17:21+16Все эти чудо технологии надо сравнивать с Delphi7 что бы стыдно было.
maxzh83
15.08.2024 17:21+3Разрабатывал на обоих и уверенно могу сказать, что WinForm сломает об колено Delphi 7.
HemulGM
15.08.2024 17:21+1WinForms годов Delphi7 - не сломает Delphi7 и близко. А WinForms современный даже не дотянется до современного Delphi
questfulcat
15.08.2024 17:21.NET Framework 1.0 появился на свет за несколько месяцев до выхода Delphi 7, конечно, по тем временам Delphi уже был колоссом.
Но уже через год Borland втащила .NET Framework в Delphi 8, и дальше в этой среде разработки пошёл какой-то кавардак...
HemulGM
15.08.2024 17:21Дальше от дотнета отказались и больше он не использовался. Хотя, в самой среде рудименты дотнета остались.
Тем не менее, vcl все это время развивается, а win forms нет.
Конечно, vcl и win forms давно не популярные в области создания оконных приложений решения, но Делфи развивает и другой фреймворк, но ближе к Avalonia, нежели к wpf.
questfulcat
15.08.2024 17:21Да, там потом и от CLX отказались. И VCL то закапывали, то откапывали. Потому так и любят многие стабильный Delphi 7.
Может VCL и развивается, в отличие от winforms, но минус в том, что за VCL надо платить (если не учитывать пробную лицензию на год с ограничениями).
HemulGM
15.08.2024 17:21VCL никогда не закапывали, Kilyx был альтернативным проектом, как и версия с .Net. На Delphi 7 сейчас только те, кто не может перевести свой проект на современные версии из-за отсутствия современных версий сторонних пакетов. Все остальные давно использую среду разработки не ниже XE7, а подавляющее большинство использует среды версий от 2018 года и выше. Например, в нашей компании есть и Delphi7 и проект, который не можем просто так перевести. И самая последняя версия Delphi 12 (2024 года) с кучей других проектов посвежее или совсем новых.
Платить нужно за все. Если проект создается для коммерческой разработки. VS тоже не бесплатная среда разработки. А для Delphi и среды разработки RAD Studio, как и для VS существует бесплатная Community версия. Для не коммерческих разработок или с ограниченным доходом.
questfulcat
15.08.2024 17:21Я не писал, что многие используют Delphi 7, я написал любят. Ностальгически, и я в их числе.
VCL закопали с приходом Delphi 8, откопали в Delphi 2005.
Для winforms можно использовать не только Visual Studio, но и бесплатные среды, и VSCode, Mono Develop, Sharp Develop, да хоть в блокноте писать без редактора, в winforms это не проблема. А потом собрать через csc.exe. Можно ли для VCL писать хоть на чём-то кроме коммерческого Delphi?
HemulGM
15.08.2024 17:21Можно писать на чем угодно, хоть дотнет приложения создавать через блокнот (есть штатный пример создания WPF), однако, компилятор тебе никто не даст бесплатно для коммерческой разработки.
rPman
15.08.2024 17:21+1.net sdk идет с компилятором, без требований и ограничений (только на распространение самих компиляторов но не на итоговые продукты, я про версии до 4-ой, которые идут в поставке с ОС), в т.ч. все то же самое и на другие продукты тиа windows scripting host (интерпретатор скриптов javascript/vbscript) или к примеру подсистема скриптов в офисных продуктах.
НО! если ваш код использует библиотеки майкрософта, то на ИХ распространение у вас может не быть прав (отличный пример, не про .net, с нативными приложениями - vcredist, вы можете дать ссылку на скачивание но не держать копию установщика, не получив на это разрешение у компании)
questfulcat
15.08.2024 17:21+1helloworld приложение:
Delphi 7: ~380 KB, только windows
WinForms .NET Framework 4.0: ~9 KB, windows, а так же linux/MacOS через mono
HemulGM
15.08.2024 17:21+2Не совсем честно сравнивать Winforms, когда у тебя рантайм на 200мб, но не в приложении. Сначала запаковать нужно, чтоб не было зависимостей. В Delphi их нет
questfulcat
15.08.2024 17:21Если бы в приложении, собранном Delphi7, не было зависимостей, то оно было бы кроссплатформенным. К сожалению, его бинарник импортирует ряд системных DLL и функций Windows API. Так что там тоже есть свой "рантайм", на который он жёстко завязан (по крайней мере VCL приложения).
Тащить локально зависимости принято у современного ".NET".
Что касается .NET Framework, то он входит в состав Windows ещё с семёрки, так что, можно сказать, тоже является частью ОС, равно как и win api, которые использует бинарник Delphi7.
Может я и ошибаюсь, но мне кажется сравнение вполне честным.
HemulGM
15.08.2024 17:21В делфи весь рантайм скомпилирован в бинарник. Естественно есть связь с winapi для создания окна (в vcl и для создания контролов). Цикл обработки сообщений является частью рантайма Делфи.
Win forms "приложение" без статической линковки по сути представляет из себя бинарный (но, не машинный) код класса юзерского решения.
В то время, как Делфи представляет из себя чистый машинный код. То, что дотнет поставляется с ОС это конечно здорово, но ведь ты не будешь сравнивать jar файл с "ехе" от дотнета, если java будет поставляться с ОС. Не говоря уже о том, что для работы дотнет приложения нужна конкретная версия этого дотнета. И почти все установщики приложений на дотнете устанавливают и дотнет нужной версии.
questfulcat
15.08.2024 17:21У меня критерий простой: устанавливаем голую винду (только не самую древнюю, которая уже не поддерживается), затем берём бинарник, собранный Delphi7, запускаем. Запускается? Да! Отлично. Теперь берём exe сборку под .NET Framework 4.x, запускаем. Запускается? Да! Без установки дополнительных пакетов, сред исполнения и прочего. Почему нечестно сравнивать такие приложения?
А тот факт, что в exe файле находится MSIL код, а не машинный - так это имеет свои преимущества - среда скомпилирует из него оптимальный машинный код под данную платформу, а затем запустит.
HemulGM
15.08.2024 17:21Запускается? Нет. Потому что проект был собран под .net 2.x, .net 3.x, .net 5.x, а в системе стоит из коробки .net 4.x. При этом, проект на Delphi7 запустится как на WinXP, Vista, Win7, Win8, Win10, Win11 и скорее всего на последующих версиях Windows на +10-20 лет вперед. Без пересборки. И без нужды ставить дополнительный рантайм.
xtraroman
15.08.2024 17:21+6Будущее за Linux. Начинать в 2024 проект который будет работать только под Windows - бесперспективно.
Дельфи и Winforms были хороши для своего времени. Мввм паттерн и биндинги там не поддерживаются. Поэтому не стоит их использовать даже для обучения или как первый проект. Научитесь плохому)
Ещё один красный флаг - технологии от Майкрософт. Они каждый год являют миру новый UI фреймворк. Забросят этот маюай прежде чем вы проект закончите.
Моя рекомендация - только Авалония
d00m911
15.08.2024 17:21+3Пока в линукс-подобных системах не доведут процесс установки ПО до схемы "установка двумя кликами по одному файлу" (утрирую, понятное дело), за будущее Windows как ведущей ОС можно не волноваться. А пока даже в самой дружественной Ubuntu процесс установки deb-пакетов - это рулетка, с высокой вероятностью ведущая в терминал)
bar2104
15.08.2024 17:21Ну, установка пакета из deb файла по факту мало чем отличается от установщик на винде. Про apt молчу, да, надо команду прописать, но уже и гуишка есть, по сути то от Microsoft store мало чем отличается, только вот MSStore почему-то не особо использую.
По поводу дороги в терминал в некоторых случаях: да, бывает, что зависимости не встают, бывает конфликт версий, да, решать через терминал зачастую. НО! Решить можно, в отличии от вины, в которой бывает, что dllка куда ни будь пропадёт. А на моем компе у меня почему то сломалась установка и удаление через msi. То есть я физически не могу поставить нужные мне программы, которые только так поставляются. А уж поверьте, раз я на линуксе сижу половину времени, некоторый опыт в гуглинге и решении проблем с компом имею. Так что этот косяк обоих систем касается
И да, я молчу о самом главном косяке винды - кодироооовки, мне кажется хоть раз в жизни(кроме случаев, когда заранее предупредили), называл пользователя кириллицей, а потом узнавал, что винду надо к чертям сносить, ибо переименовать то можно, но вот с системными папками сложнее
xtraroman
15.08.2024 17:21Проблема инсталлеров Линукс конечно есть, но ее научились решать. Сходу можно провести примеры: установщик Steam, установщик Cura. Вполне дружелюбные. Многочисленные пользователи их осилили.
piton_nsk
15.08.2024 17:21+5Дельфи и Winforms были хороши для своего времени. Мввм паттерн и биндинги там не поддерживаются.
Да ладно.
this.data = new DataSourceForButton() { StringData = "Lol" }; button1.DataBindings.Add(new Binding("Text", this.data, "StringData", true, DataSourceUpdateMode.OnPropertyChanged)); button1.DataContext = this.data;
xtraroman
15.08.2024 17:21Привязки к view model в коде выглядят громоздко. Попробуйте то же самое написать на xaml платформах. Получится гораздо элегантнее. Не стоит откапывать winforms, оставьте его в покое )
piton_nsk
15.08.2024 17:21+2Я писал на XAML и знаю что там и как, речь о биндингах в Winforms, которые "не поддерживаются".
xtraroman
15.08.2024 17:21Можно ли сказать что winforms формально поддерживает mvvm? Да можно. Вы правы.
Можно ли это рекомендовать для обучения и для новых проектов?
Нет.
Код который вы показали - плохой. Его долго писать. Долго читать.
stan1901
15.08.2024 17:21+4Годами использовал биндинги в WinForms, а его нет, оказывается :) Работал он не идеально, но работал. Проблема у WinForms была в другом - он на каждый элемент управления создавал окно Windows, из-за чего сложные формы тормозили. Интереса ради как-то сделал форму с большим количеством полей ввода на WinForms и такую же на HTML - HTML-форма в Google Chrome работала гораздо быстрее WinForms.
В-общем, если не нужны изыски отрисовки, то даже "голый" WinForms без специальных стилизованных элементов управления способен решать многие задачи (кроме разве что табличного ввода - он без доработки напильником не работал).
HemulGM
15.08.2024 17:21+1В Delphi изначально MVP, и никто не запрещает реализовать MVVM. И да, биндинги там тоже есть, даже в старом добром VCL. Визуально создаются, кстати. А кроссплатформенный FMX куда эффективнее Avalonia
suprunchuk
15.08.2024 17:21+2Ничего лучше tauri пока не нашел. Да не C# ваш. Но это мега крутой фреймворк.
Tsx + Rust.
Жирный плюс по сравнению с тем же Electron в том, что tauri переиспользует уже установленный webview в систему. на windows это edge, на mac это WebKit.. А electron каждый раз пихает в сборку .exe свой движок. За что размер приложения со старта 5 Мб на таури, и 180 Мб у электрона.
Всем советую Tauri!
Einherjar
15.08.2024 17:21+8Хорошии обзор, но имхо крестики-нолики слишком простой пример для сравнения фреймворков, фактически это 9 кнопок и все, это так или иначе по силам любому фреймворку. Вот какая-н таблица с сортировкой и, скажем, комбобоксами в ячейках, и привязанная к данным тысячи хотя бы на три строчек сразу отделяет мух от котлет и показывает с каким фреймворком можно работать, а какой упоминать можно разве что только ради шутки. Две трети сойдут с дистанции еще на этапе разработки. Но конечно такой пример 6 раз для статьи сделать может быть весьма трудоемко
comradeleet
15.08.2024 17:21Два примера хватит, один под формы, второй под mvvm, + немного подкрутить индивидуально
piton_nsk
15.08.2024 17:21Тут уже больше зависит от библиотек, одно дело дефолтный грид, другое девэкспресс.
Einherjar
15.08.2024 17:21Наличие сторонних библиотек, степень их убогости и суммы которые за них хотят (и заплатив которые все равно придется потратить на пляски с бубном с воркараундами вокруг бесчисленных багов в них столько же времени сколько на написание собственных контролов) это тоже вполне себе важные критерии для оценки UI-фреймворка.
Zerpico
15.08.2024 17:21Было бы неплохо ещё оценить нагрузку в контейнерах, например списки, таблицы и т.п. Желательно около 1000 элементов в них и посмотреть нагрузки, память, скорость прокрутки, есть ли кэш или отложенная загрузка.
questfulcat
15.08.2024 17:21Как я понял, startup time измеряется так:
# Ждем, пока главное окно приложения не станет отзывчивым
while (-not $process.MainWindowHandle)
...Мне кажется, тут довольно скользкий момент. Не понятно, в каком фреймворке как это устроено. В одних оно может стать отзывчивым до момента инициализации и отрисовки, в других - после. Я бы просто добавил вызов Close() в конце конструктора формы, после всех инициализаций, чтобы приложение запускалось, инициализировалось и сразу закрывалось. И измерил бы общее время работы процесса. Просто как вариант...
И жаль, что нет сборки WinForms под .NET Framework 4.x. Они совсем ведь разные фреймворки с .NET
Superzoos
15.08.2024 17:21Статья очень вовремя, как раз перехожу с C++ и Windows Forms на C# и WPF. Uno Platform раньше даже не слышал. Спасибо за статью!
Wolfdp
15.08.2024 17:21По опыту замечу что "простота winforms" крайне обманчива. Как только пытаешься в что-то сложнее крестиков-ноликов, то сложность работы через графический редактор крайне возрастает. XAML в плане организации UI гораздо лучше, хоть и приходиться потратить время на "разобраться".
Также отмечу что WPF поддерживает графическое ускорение, что позволяет с легкостью переваривать 100500 элементов в окне. Для форм такое издевательство нередко превращается в слайдшоу.
Дополнительный минус для winforms, что размеры контролов окна работают в разрезе 16 бит, причем в коде Size или Point имеют 32 битные поля и никаких ошибок в процессе не получаешь. Просто при переполнении, элемент улетает в непонятную часть окна.
И как вишенка на торте, я не завидую тому человеку, которому придеться поддерживать hight dpi на winforms.
С учетом всего этого, я очень скептически отношусь к идеи связываться с winforms, когда есть альтернатива в виде wpf. Особено в плане обучения. XAML всеже больше про разметку через теги, а не работу в графическом редакторе. В итоге приходиться ломать привычные подходы на новые.
P.S. Возможно из плюсов будет тот факт, что в winforms довольно просто нарисовать свой произвольный элемент. Хотя я не особо разбирался насколько это сложно в wpf.
ilyachudin
15.08.2024 17:21Поддержку win нужно делить на Win XP/7+ и Win10+ (да xp имеет место жить в кровавом энтерпрайзе)
Avalonia не использует WinUi (!) - там честный кросплатформенный рендеринг на векторах
PsychoGod
15.08.2024 17:21Спасибо за статью!
Хотелось бы узнать ещё по каждому фреймворку — что по комьюнити, насколько живое/неживое, и есть ли плагины, библиотеки, дополнения к ним, всякие recycleview и т. д., нужны они вообще или нет, насколько сложно сделать сильный кастом-комплект и использовать его как библиотеку к разными проектами.
freemorger
Uno выглядит неплохо для разработки на линукс. Хотя для линукса легче уж GTK или Qt использовать