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 01:17 am (UTC)
From: (Anonymous)
В последнее время твои посты по-особенному радуют и вцелом со многим я согласен, но вот здесь критически нет:
> рефлекшн, и вообще, динамика - один из ключевых столпов WPF, в самом дотнете совершенно неюзабельны
> Объектная система невероятно убога и примитивна
> Интроспекция - очень сильно ограничена и неудобна в использовании
> Система типов скорее мешает разработке, чем помогает
Юзабельность - это вопрос выразительности языка и интерфейса. Касательно конкретно C# я бы еще понял такую позицию, но не платформы.
Где ограничена интроспекция? Тут уж подавай задачку - сегодня вечером попробую решить.
У меня на работе много вещей, где система типов очень помогает, хотя бы потому, что без волшебного интеллисенса, точки и тайпчека удерживать в голове настолько монструозный мир очень сложно, а мир этот регулярно морфирует, в соответствии с решениями коллег, фантазиями "архитекторов" и заказчиков.
Кстати, смотри: http://msdn.microsoft.com/en-us/library/system.dynamic.dynamicmetaobject.aspx

Date: 2011-01-19 05:39 pm (UTC)
From: [identity profile] love5an.livejournal.com
>Тут уж подавай задачку - сегодня вечером попробую решить.

http://love5an.livejournal.com/358294.html

>хотя бы потому, что без волшебного интеллисенса, точки и тайпчека удерживать в голове настолько монструозный мир очень сложно

Ну да, студия крутая. Но SLIME тоже ничего так помогает удерживать в голове большую систему(в CL тоже таки декларации типов есть, SLIME их умеет парсить).
Про удобство - я имел ввиду в основном в контексте C#, конечно.

>http://msdn.microsoft.com/en-us/library/system.dynamic.dynamicmetaobject.aspx

Ну, двигаются в правильном направлении. Но опять же - все переусложнено и окостылено просто пиздец.

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. 14th, 2025 03:03 pm
Powered by Dreamwidth Studios