WPF

Jan. 19th, 2011 12:00 am
love5an: (Default)
[personal profile] love5an
WPF охуенно. WPF круто, нереально круто.

GTK+ - говно. Qt - говно. wxWidgets - говно. Tk - говно. Pure Winapi, MFC, ATL, WTL - говно. Windows.Forms - говно. Cocoa - говно. SWT - говно. Swing - говно. Все это блевотное говно.

А WPF пиздато.

Проблема в том, что WPF переусложнено. Сильно переусложнено. Да, оно многое позволяет, оно очень хорошо отделяет интерфейс от реализации, оно расширяемо, оно интероперабельно с WinAPI, оно использует ресурсы видеокарт для отрисовки. Но, WPF очень сложное, слишком. И подпертое костылями со всех сторон.

И, да, это проблема не только WPF - это проблема практически всех продуктов и технологий Microsoft.

Проблема в том, что в Microsoft работают гениальные инженеры, разработчики и архитекторы, гениальные дизайнеры, гениальные менеджеры. Но, ориентируется Microsoft на рядового пользователя и на рядового разработчика - именно это обеспечивает коммерческую успешность компании. А гениальные технические и дизайнерские задумки довольно хреново ложатся на инфраструктуру, нацеленную на рядовых разработчиков и пользователей.

MS, например, прямым текстом признается, что семантика .NET-языков, и самого дотнета - слишком примитивна, убога и нерасширяема, и недостаточна для красивой реализации dataflow gui-фреймворка:
http://msdn.microsoft.com/en-us/library/ms750441.aspx#System_Windows_DependencyObject
Отсюда все эти костыли типа DependencyObject и прочая.

Кроме того, рефлекшн, и вообще, динамика - один из ключевых столпов WPF, в самом дотнете совершенно неюзабельны. Объектная система невероятно убога и примитивна. Интроспекция - очень сильно ограничена и неудобна в использовании. Система типов скорее мешает разработке, чем помогает. Про функциональное программирование я вообще промолчу(хотя где-то версии с третьей дотнета с этим стало получше, конечно).

Отсюда вся эта сложность, отсюда все эти костыли. Но это не избыточная сложность, на самом деле. Это просто плата за попытку реализовать гениальные идеи с помощью примитивных инструментов.


На Common Lisp парадигмы event-driven и dataflow программирования ложатся идеально.
http://common-lisp.net/project/cells/

И динамичности в нем предостаточно.

Но Microsoft никогда бы не стала реализовывать свой передовой фреймворк на платформе типа CL. Он слишком отличается от других языков. Он сложен. А где найдешь программистов на нем? И кто будет этим пользоваться? Кучка энтузиастов?

Любую корпорацию, даже связанную с высокими технологиями, технологии не интересуют. Ее интересует стабильность и финансовые потоки.

Date: 2011-01-19 05:58 am (UTC)
wizzard: (Default)
From: [personal profile] wizzard
Дотнет бывает маленький. Тоже с WPF-ом, кстати. Windows Phone тому примером.

Date: 2011-01-19 02:19 pm (UTC)
From: [identity profile] alex bubnoff (from livejournal.com)
он бы еще на десктопах маленький бывал.
и вообще, винда, к сожалению, не дебиан - она тебе сама не установит зависимости, какие укажешь. я не хочу полагаться на людей, которые зачастую не понимают, зачем вообще у софта бывают зависимости. хотя это уже мои личные комплексы, наверное.

Date: 2011-01-19 09:01 pm (UTC)
wizzard: (Default)
From: [personal profile] wizzard
Мне кажется, о зависимостях должен думать мейнтейнер дистриба аппликухи, т.к. он про них знает лучше, чем мейнтейнер ОС.

Вот адобовский софт, к примеру - говно (с точки зрения безопасности), но зависимости свои как-то менеджит. Студия тоже менеджит. И дает при краше какого-то приложения выбирать дебаггер, например, если в системе их установлено несколько. Почему товарищи в линухе не могут такое сделать?

Я, вообще, соглашусь, что MSI в базовом варианте полагается только на "модули", которые не совсем то, но зато их можно устанавливать и удалять в любых комбинациях и любом порядке, это хорошо, робастно и правильно.

Profile

love5an: (Default)
Dmitry Ignatiev

June 2020

S M T W T F S
 123456
78910 111213
14151617181920
21222324252627
282930    

Most Popular Tags

Page Summary

Style Credit

Expand Cut Tags

No cut tags
Page generated Jul. 23rd, 2025 01:57 am
Powered by Dreamwidth Studios