Название: У кого приходили мысли - сложно ли сделать свой фреймворк типа Qt? Отправлено: kkmspb от Сентября 20, 2025, 14:12 Я тут новичок, но Qt использую давно и до сих пор сижу на Qt4 , но речь не об этом. В основном кодю десктоп приложения под винду. И все у меня хорошо, на мой взгляд, все меня устраивает. Чего не хватает в Qt развиваю сам, т.е. добавляю новый функционал, в основном в ветке qt/sql.
Но, по мере погружения в исходники Qt (500 классов вроде), часто стал задумываться - а в чем трудность сделать свой фреймворк и почему таких с++.фреймворков по пальцам пересчитать, при чем одной руки? Хочу изложить, какое у меня сложилось понимание основных моментов, на которые надо сразу обратить внимание. В чем основные моменты базовых классов. 1. Как ни странно это реализация очереди сообщений от операционной системы. 2. Метаобъектная система, реализация своего QObject аналога. Тут же и технология сигнал/слот как следствие, причем межпоптоковый вариант тоже должен быть и как раз через очередь сообщений каждого потока отдельно его надо реализовывать. 3. Как ни странно это общий тип данных по примеру QVariant, чтобы кастовать туда сюда разные типы данных как хочу на основе кастомных метаданных, очень удобная фича. 4. Гуй всемогущий! Реализовать парадигму отрисовки виджетов с применением для этого лейаутов или чего-то подобного. 5. Наконец-то сделать нормальные классы для работы с базами данных, CRUD, внешние связи и.д. Но это уже детали. 6. Конечно сетевой протокол с использование openssl не забываем. Чего ещё забыл? Ах да, надо лет 7 свободного времени. Но по факту Хаавард Норд на пару с ещё с одним студентом сделали эти примерно 500 классов лет за семь, насколько я знаю. Причем с учётом кроссплатформенности, но я лично ограничился бы для себя виндой пока, хоть это и кощунство. И наконец я бы разрешил все это добро использовать под лицензией - как хочу так и пользуюсь, хоть в закрытых проектах, хоть в открытых, хоть в коммерческих, хоть в бесплатных, компилировать хоть динамически/ хоть статически. 7. Наверное забыл контейнеры типа QMap, QList и т.д. Название: Re: У кого приходили мысли - сложно ли сделать свой фреймворк типа Qt? Отправлено: kambala от Сентября 20, 2025, 17:21 версия 1.0 (которую видимо за 7 лет и написали) порядочно отличается даже от 4-й. А сколько всего добавили в 5 и 6 уж можно и не говорить.
наверное никому неохота переизобретать колесо с сомнительным выхлопом. И наконец я бы разрешил все это добро использовать под лицензией - как хочу так и пользуюсь, хоть в закрытых проектах, хоть в открытых, хоть в коммерческих, хоть в бесплатных, компилировать хоть динамически/ хоть статически. у Qt нет с этим никаких проблем. Или щас опять пойдут байки про «если линковать статически, то надо открывать код приложения»? :)Название: Re: У кого приходили мысли - сложно ли сделать свой фреймворк типа Qt? Отправлено: sergek от Сентября 20, 2025, 18:10 Коллега - провокатор)) И все ж...
Зачем класть 7 лет (:D) на разработку того, что уже есть? Форкнуть, к примеру, 5.15, выкинуть лишнее, добавить недостающее, послать фиников на ..., изменить лицензию на "всем всё разрешено", и все дела. Понимаю, тем, кто до сих пор работает на забугор, это не понравится, но у них и так все хорошо. А все остальные будут довольны. Название: Re: У кого приходили мысли - сложно ли сделать свой фреймворк типа Qt? Отправлено: kkmspb от Сентября 21, 2025, 10:51 Коллега - провокатор)) И все ж... Зачем класть 7 лет (:D) на разработку того, что уже есть? Форкнуть, к примеру, 5.15, выкинуть лишнее, добавить недостающее, послать фиников на ..., изменить лицензию на "всем всё разрешено", и все дела. Понимаю, тем, кто до сих пор работает на забугор, это не понравится, но у них и так все хорошо. А все остальные будут довольны. В общем я сейчас так и поступаю, но на Qt4. Это к вопросу, что в Qt 5,6 дофига чего добавлено. На самом деле я до сих пор не вижу необходимости переходить на Qt5. Но посылать фиников я тоже никуда не хочу, просто если так складывается, что развитием Qt Sql я занимаюсь индивидуально, там модель данных уже полностью своя и представление свое (отрисовка) , то может уже пора и все исходники переработать? Чего нам терять то? Правда времени сейчас не хватает, т.к. на том же Qt4 пишу десктопы и довольно успешно, но заяб..ют разговоры, что я кому-то должен исходники открывать (релиз собираю исключительно статически). |