Предлагаю вскрыть эту наболевшую тему, от которой зависит наше с тобой, анон, будущее.
Часто в темах /pr/ вижу: "у десктопа нет перспектив, перекатился в веб, плююсь, но осваиваю" Да и вообще вокруг в статьях (на том же хабре) можно слышать: веб-веб-веб, десктоп умрёт не сегодня-завтра, кто не с нами тот под нами etc
На мой взгляд тенденция к переходу в веб имеется, однако скорость её значительно приукрашена маркетологами и разогрета всеобщим хайпом.
Сужу по своим ощущениям: впервые вкатился в веб году этак в 2004, ещё зелёным сосницким, помню тогда восхитило, как легко в блокноте можно сделать НОСТОЯЩИЙ САИТ который будет виден ВСЕМУ МИРУ. Немного покодил на PHP, JSа вообще не касался, он казался кривой инопланетной технологией (забегая вперёд: в 2016 такой и остался) и оставил это дело. Писал по учёбе всякие десктопные консольные и GUI программки и был доволен.
Затем второй раз вкатился в 2010, на практике в универе. В вебе явно наметились изменения: все заговорили о ФРЕЙМВОРКАХ. Пощупал их, понял что движение есть, но веб остаётся всё тем же кривым франкенштейном, "я тебя слепила из того что было", собранным по нитке со всего мира, с кучей несовместимостей и костылей. Снова выкатился.
Сейчас, в 2016 поглядываю, почитываю статейки и вижу, что паровоз хайпа лишь ещё больше разогнался. Технологии меняются по годам и месяцам, льётся поток новых баззвордов, но развитие остаётся количественным, качественных же улучшений как не было так и нет.
Почему, на мой взгляд, веб это не замена десктопа: 1. Взаимодействие с компьютером пользователя, да и с ним самим, возможно лишь через стороннюю левую программу - браузер. Заменить браузер самописным - невозможно. Поэтому ты всегда ограничен его возможностями. Никакой интеграции с ОСью, никакого удобства. Только какие-то невнятные уведомления, которые юзер ещё должен разрешить.
2. Сами браузеры - тормозные (кроме хрома), жрущие память чудовища, для одинаковой работы сайта в которых нужно предпринимать отдельные усилия, и в которых сайтовый функционал легко зафейлить, не поставь юзер нужный плагин или поставь ненужный (адблок, или что-нибудь для безопасности, режущее следилки)
3. Горячие клавиши, интерфейс (правый клик мыши) в интерфейсе сайтов конфликтует с оными сочетаниями самого браузера. В том же ютубе чтобы управлять видео через кнопки J-K-L нужно чтобы ютуб был открыт на отдельной странице (не встроенный) и чтобы фокус был в окне видео. Для юзера это выглядит чужеродно (никакой интеграции со стилем операционки), и нихрена не интуитивно.
4. Для создания интерактивности на выбор предлагается лишь JavaScript - то ещё говноподелие с обширным списком "рафик, это неувозможно пониять, ето нада зопомнить"
5. Хранение твоих дорогих данных "где-то там" и постоянная пересылка их по сети туда-сюда. Впрочем об этом сказано достаточно
6. Загрузка-выгрузка данных из облачного сервиса (для бекапа, импорта в другую прогу) возможно только настолько, насколько её реализовали создатели сервиса. Сервис упал, закрылся, заддосен - ты соснул. В случае же десктопной программы - всегда можно либо открыть файл сторонним софтом, либо в крайнем случае попросить знакомого программера написать парсер. Структурированные данные не потеряются.
Итого: при текущей скорости развития, веб не заменит десктоп ещё без малого 10-20 лет. А может и долше, т.к. этот процесс замедляется отсутствием качественных языков для разработки новых веб-браузеров, компиляторов, интерпретаторов (языков, которые придут на замену js). Перспективные D, Rust, Dart etc пока лишь на подходе и когда войдут в продакшн - неизвестно.
Поэтому возникает вопрос к анону: зачем досрочно валить с десктопа, жрать веб и лишь приумножать безумный хайп непродуманности и кривости нынешнего веба?
Неужто не хватает работы? На контор, пилящих на C#/Java/C++ - полно!
Лично я остаюсь кодить на качественных, проверенных временем десктоп технологиях, чтобы, если уж случится чудо и на моём веку придёт настоящий, не дутый расцвет веба, преспокойно и вальяжно вкатиться на всё готовенькое. Ведь я ценю своё время.
>>768500 кстати про мобилочки. Лично я скептически настроен к ним. Как средство общения - они да, полезны. Ну ещё - для выполнения узкоспециализированных задач, когда работодатель предоставляет специально разработанное мобильное приложение, ты там ходишь по складу или по лугам-лесам и отмечаешь какие-нибудь товары или точки.
В остальном же - для игр, создания контента, да даже полноценного сидения в интернете - персональные компьютеры с клавиатурой и мышью вне конкуренции.
p.s. Говорю не просто так, был у меня одно время планшет, хороший, дорогой, от Samsung. Большую часть времени пылился. Ну тупо неудобно на маленьком тач экранчике что-либо вменяемое делать.
>>768485 (OP) ОП, я тебе объясню почему все постепенно перекатились в веб, хоть это и лютая параша. Причина в кряках и кейгенах. На десктопе есть вохможность сломать любой покупной софт. А на вебе у тебя нет такой возможности. В результате теперь даже 3д моделинг планируется делать в вебе. Такой-то отсос мамкиных крякеров.
>>769459 >В результате теперь даже 3д моделинг планируется делать в вебе. Такой-то отсос мамкиных крякеров. С фпс 10. Такой-то отсос маминых моделлеров.
1) Браузеры начинают поддерживать WebAssembly 2) Гугл и микрософт выпускают свои UI фреймворки под него. 3) Все начинают пилить сайты в идешках аля Android Studio или вижуале. Те ествественно работают на любый устройствах где есть браузер, а главное нативно. 4) ??? 5) хтмл только на википедии
>>769459 Хуита. Кряки и кейгены даже в этой стране существенно влияют на продажи только в бесогоновом манямире, а у них там вообще культура крэкинга неразвита, а немногие страждущие вынуждены на руборды всякие ходить за кряками. И потом, как заметил >>769469-кун - либо ты убираешь тяжелую логику в облако и получаешь нерентабельное дерьмо, когда на трех клиентов нужна дополнительная невиртуальная машина, либо ты загружаешь основной код пользователю и выполняешь в браузере, и тогда это все ломается еще легче, чем десктоп.
>>769482 Дело не в языках программирования, а в API. Уже и так есть компиляторы каких угодно ЯП в JS, но от этого ничего не меняется, т.к. в конечном счёте всё упирается в DOM API.
>>769482 ВебАссембли - это JavaScript, который заранее распарсили. Это никаким местом не ассемблер, как некоторым может показаться из названия. Ему по определению никогда не достичь скорости нативного кода. По этой и другим причинам можно уже сейчас считать, что он не взлетел.
>>769767 У JVM заебись скорость, особенно если памяти побольше выделить и -X опции потюнить. У NET похуже, но если за трафиком в памяти следить, тоже нормально. Чего ты вообще уперся в слово виртуальная машина? У любого языка есть рантайм, и у почти любого (кроме сишечек) он ничем от виртуальной машины не отличается
>>769815 У .NET должна быть выше, ибо при запуске программы он полностью компилирует ее в машинный код, а JVM лишь некоторые (часто используемые) части.
>>769815 > заебись скорость Заебись не значит нативная. 64 Гб хватит всем, да. > уперся в слово виртуальная машина Почему то, если написано assembly, многие начинают течь, думая о скорости и о том что это ассемблер для настоящего железного процессора. А там абстрактная виртуальная машина >>769820 Jit как бы говорит тебе, что .net не так работает.
>>769833 > Почему то, если написано assembly, многие начинают течь, думая о скорости и о том что это ассемблер для настоящего железного процессора. А там абстрактная виртуальная машина Скорость в разы выше потому что не надо парсить исходники. К примеру, в Delphi тяжелые проекты собирались максимум за несколько секунд. А в C++ сборка могла заняться на полчаса, т.к. компилятору нужно было парсить текстовые .h файлы.
>>769844 Если это работает охуенно быстрее заранее скомпилированного нативного кода, то почему тогда интерпретатор жабы пишут на машинном коде, а не на байт-коде с JIT? Почему игори пишут на нативном коде?
>>769850 Не придумывай, про охуенно быстрее никто не говорил. Это зависит от многих факторов. Что касается JVM, то возможности в рантайме исполнять на ней код дает много полезных возможностей, начиная от reflection до bytecode injection в мирных целях. У каждого подхода есть свои плюсы и свои минусы. Пиздеть же про нативный код в 2016 году когда вокруг много очень хорошо оптимизированных JIT-компиляторов - неумно.
>>768485 (OP) >тенденция к переходу в веб имеется, однако скорость её значительно приукрашена маркетологами и разогрета всеобщим хайпом.
This. А хайп создается Гуглом и прочими госдеповскими конторами. У нас и так уже почта не стирается, все файлы "в облаке", осталось ещё все программы туда перевести.
Однако надо знать и то и другое. Я, например, много работаю с консольными приложениями (т.е. создаю их), windows services (то же, но в профиль) и веб сервисами, то есть создание интерфейсов в вебе приходится делать не столь часто, как всё остальное. У каждого нормального вебсайта есть бэкэнд нагрузка из баз данных, утилит, сервисов, порой вообще клиентов для суппорта, т.е. веб интерфейс это только верхушка айсберга.
>>769850 При предварительной компиляции нужно быть очень консервативным с оптимизацями, т.к. не дай бог из-за какой-то оптимизации наоборот всё будет медленне работать (ибо ты не знаешь, как именно будет в реальности использовать твой кусок кода) JIT компилятор может быть очень оптимистичен с оптимизациями, если что-то будет работать медленно - он эти оптимизации легко может откатить.
>>769838 Ебать дебил. Модули вместо хидеров не дадут сильного прироста скорости компиляции (посмотри на тот же раст – компилируется подольше плюсов, а ведь с модулями). Паскаль – это такой вид оберона (или наоборот, или я вообще спутал с модулой – один хуй виртовские языки на одно лицо), который в свою очередь разрабатывался как язык для обучения написания компилятора, с минималистичным AST и синтаксическими заёбами.
Попробуй написать парсер паскаля, а потом хотя бы плюсов года так 98 (молчу про последние), посмотри в чём же там разница.
Алсо, про говно вместо оптимизатора который тоже кушает время лучше, наверно, не вспоминать.
> Итого: при текущей скорости развития, веб не заменит десктоп ещё без малого 10-20 лет. А может и долше, т.к. это никому не нужно, кроме кучке хипсторов
>>769482 >WebAssembly Заведомый фейл. Браузер и так компилирует Javascript в байткод (или даже нейтивный для проца код). А теперь этот новый байткод надо на виртуальной машине гонять. И чтобы для мипсов там всяких, ARMов тоже пошло. Все это говно будет работать медленнее, чем сейчас. Выигрыш только за счет сокращения времени на компиляцию, но он незначительный. Пока ресурсы сайта грузятся, едро линупс скомпилировать можно. Байткод можно в кэше хранить, и тогда вообще выигрыша нет. Главные тормоза в браузере - это DOM.
>>776001 >А теперь этот новый байткод надо на виртуальной машине гонять. Вась, разработчики браузеров не настолько уебаны чтобы запускать любую страницу вне виртуалки, это не безопасно и текущие бровсеры так и работают.
>>776075 >разработчики браузеров не настолько уебаны После того, как последняя версия Хрома выгружает неактивные табы из памяти и вообще нахуй, а при активации закладки заново грузит её из интернета - я уже ничему не удивлюсь. А про JS движок вот что в википедии >V8 compiles JavaScript to native machine code (IA-32, x86-64, ARM, or MIPS ISAs; has also been ported to PowerPC[7] and IBM s390[8][9] for use in servers)[3][10] before executing it, instead of more traditional techniques such as interpreting bytecode
>>776001 > Главные тормоза в браузере - это DOM. WebAssembly и продвигается для разработки "низкоуровневых" программ (в частности игр), а не как замена JS.
Так где мегабайты кода и много вычислений (и отрисовка через WebGL), там и нужен WebAssembly. Кстати, обещают и нормальную многопоточность завезти.
>>776452 >Так где мегабайты кода и много вычислений (и отрисовка через WebGL), там и нужен WebAssembly. Упаси боже, кому и зачем это говно нужно? Зачем его тащить в гипертекст? Ну придумайте вы спецификацию тонких клиентов, и пилите их отдельно, зачем поганить браузеры? Они не для этого. С самых девяностых пердолятся с ними, костыль на костыле.
>>769668 На волне всеобщего хайпа, который они сами и поднимают. Нужно искать причину возникновения этого хайпа. Как по мне -- так это заговор >>769490 Сука, ты в зк зашёл чтобы подрочить?
>>777035 Ты не различаешь байки о дырах из 1997 года в Java-рантайме и уровень дыр современных браузеров, в латание которых уже вложено человеко-часов больше чем во все полеты на Луну?
>>769668 >Нужно искать причину возникновения этого хайпа Это как мода у баб, она иррациональна и непредсказуема. Просто кто-то сказал, что инпуты без рамок это круто, и теперь все так делают, хотя ни одного убедительного аргумента в пользу такого решения нет. Точно так же и с вебом. Десктоп для замшелых пердунов, планшет это стильно, молодежно и инновационно, давайте все делать на планшет. Прагматичных гиков в процентном соотношении становится все меньше, они уже не могут задавать тренды. Это печально.
Вот она пропаганда. Про дырявый флеш, о каждой уязвимости которого кричат на каждом углу все гуголы с эплами и мозилами, знает каждый, а про баги в браузерах (которых не меньше, на самом деле, просто все молчат, ибо кричать не выгодно) никто не слышал. Ещё и сомневаются, есть ли они.
Десктоп не умрет потому что он уже давно умер. Сейчас нет никакого смысла шквариться об кутэ и прочее говно, в плане построения гуйни хтмл дает посасать чему угодно. Если жмет песочница то достаточно обернуть вэбню в nwjs или electron.
>>769668 Скорость разработки. Особенно если нужно нацелиться на кучу платформ. Верстать под браузеры таки проще. С другой стороны, не забывай о компаниях, пилящиее приложения под десктоп. Пусть это и обертки сайта на электроне/node-webkit. Но, внезапно, их делают ради использования нативных функций платформы, типа уведомлений, выбор звуковых устройств ввода, нормальная работа с файловой системой, етц.
>>778073 QtWebEngine в продакшене не используется? Да молодой еще. Но был же еще QtWebkit. Или вот QtScript. Хоть он и deprecated но на сервер как обработчик запросов годнота.
>>778076 Не рынок порешал, а порог вхождения в разные технологии. Пользоваться гипертекстовой разметкой большинство людей еще в школе учат. А в Java или C# огромнейшие стандартные библиотеки. Awt, swing, swt\win forms, wpf, gtk#, офигеешь. >>778078 Это все неудобно, особенно C++, особенно если нужно кроссплатформенную сборку пилить. Это ведь надо с версиями qt ебаться, с зависимостями под Linux быть знакомым, даже возможно опакетить бинарник. А так у тебя лежит в бинарном виде движок какого-нибудь электрона под все доступные платформы, который отдельно обновляется. Отдельно внутренности проекта на js+css+html, и из всей этой веб ебалы одним коротким скриптом генерятяс релиз и дебаг билды. Это так, взгляд со стороны.
Неужто не хватает работы? На контор, пилящих на C#/Java/C++ - полно! Подскажи конторы где нужен Java программист с Swing, JavaFX? Spring не знаю, в вэб не берут и не хочу сам. Текущая шарпоработа надоела.
Тред не читал, но похуй. Веб действительно намного мощнее в графическом плане чем десктоп. Веб кроссплатформенный (а точнее кроссбраузерный). Есть сотни тонн готовых решений. Но! Не забываем, что есть действительно проекты, которые в вебе ни в сраку совсем. (Чаще всего всё то, что много работает с файловой системой, например). Для таких вещей десктопные приложения банально удобнее. И для создания десктопных приложений без всякого геморроя на помощь приходит ElectronJS! Сама крутая хуита, вертится внутри ноды, рендерится хромиумом. Пиши десктоп на html и js! Смело, модно, молодежно!
>>778233 Пока ты будешь настраивать апп-сервер, деплоймент, тесты, CI и ехал бин через бин по XML, на NodeJS уже сделают еботень, выставят в энторнеты, наберут пользователей и получат венчурный лям на дальнейшее развитие.
>>778335 Конечно получишь. Вот Гугл выпустил социальную сеть Google Plus, и получил пользователей Facebook себе. И все остальные тоже, выпустили свои соцсети и получили пользователей Facebook себе.
Как ни печально Анон. Я начинаю терять веру в языки программирования, мне нравится Java. Просто нравится. Но реальность показывает, что теперь важна скорость генерации говна,меня расстраивает перспектива, того что эта реальносит не оставит мне завтра выбора, и мне придется писать код на языке под название ЖС. Sad but true. з.ы. хипсторы - пидоры з.ы.ы. развалили отрасль з.ы.ы.ы. 3310 каждому в жопу
>>781563 >мне нравится Java. Просто нравится Тут вариантов два 1. Ты обычный говноед. 2. Ты имеешь опыт программирования на десятке разных языков разных парадигм и дополнительно еще на двух-трех немного странных языках, и тебе из всех них нравится именно Java - ты очень извращенный говноед.
> развалили отрасль К языкам Java и Javascript это не имеет почти никакого отношения. Внезапно выяснилось что лепить говновеб на серьезных и надежных технологиях - непозволительный перерасход ресурсов. А из серьезного бэкенда (того что за веб-бэкендом) Java никуда деваться не собирается. Только джуниоры в этом серьезном бэкенде нахуй не нужны, особенно толпы их.
>>768485 (OP) Как бальзам на душу. Только вот в вебе найти работу на порядок проще, чем в десктопе. Даже основной язык менять собрался на что-нибудь хардкорно десктоп, потому что веб-веб-веб-веб какой ты вообще кодер если не веб
Часто в темах /pr/ вижу: "у десктопа нет перспектив, перекатился в веб, плююсь, но осваиваю"
Да и вообще вокруг в статьях (на том же хабре) можно слышать: веб-веб-веб, десктоп умрёт не сегодня-завтра, кто не с нами тот под нами etc
На мой взгляд тенденция к переходу в веб имеется, однако скорость её значительно приукрашена маркетологами и разогрета всеобщим хайпом.
Сужу по своим ощущениям: впервые вкатился в веб году этак в 2004, ещё зелёным сосницким, помню тогда восхитило, как легко в блокноте можно сделать НОСТОЯЩИЙ САИТ который будет виден ВСЕМУ МИРУ. Немного покодил на PHP, JSа вообще не касался, он казался кривой инопланетной технологией (забегая вперёд: в 2016 такой и остался) и оставил это дело.
Писал по учёбе всякие десктопные консольные и GUI программки и был доволен.
Затем второй раз вкатился в 2010, на практике в универе. В вебе явно наметились изменения: все заговорили о ФРЕЙМВОРКАХ. Пощупал их, понял что движение есть, но веб остаётся всё тем же кривым франкенштейном, "я тебя слепила из того что было", собранным по нитке со всего мира, с кучей несовместимостей и костылей. Снова выкатился.
Сейчас, в 2016 поглядываю, почитываю статейки и вижу, что паровоз хайпа лишь ещё больше разогнался. Технологии меняются по годам и месяцам, льётся поток новых баззвордов, но развитие остаётся количественным, качественных же улучшений как не было так и нет.
Почему, на мой взгляд, веб это не замена десктопа:
1. Взаимодействие с компьютером пользователя, да и с ним самим, возможно лишь через стороннюю левую программу - браузер. Заменить браузер самописным - невозможно.
Поэтому ты всегда ограничен его возможностями. Никакой интеграции с ОСью, никакого удобства. Только какие-то невнятные уведомления, которые юзер ещё должен разрешить.
2. Сами браузеры - тормозные (кроме хрома), жрущие память чудовища, для одинаковой работы сайта в которых нужно предпринимать отдельные усилия, и в которых сайтовый функционал легко зафейлить, не поставь юзер нужный плагин или поставь ненужный (адблок, или что-нибудь для безопасности, режущее следилки)
3. Горячие клавиши, интерфейс (правый клик мыши) в интерфейсе сайтов конфликтует с оными сочетаниями самого браузера. В том же ютубе чтобы управлять видео через кнопки J-K-L нужно чтобы ютуб был открыт на отдельной странице (не встроенный) и чтобы фокус был в окне видео. Для юзера это выглядит чужеродно (никакой интеграции со стилем операционки), и нихрена не интуитивно.
4. Для создания интерактивности на выбор предлагается лишь JavaScript - то ещё говноподелие с обширным списком "рафик, это неувозможно пониять, ето нада зопомнить"
5. Хранение твоих дорогих данных "где-то там" и постоянная пересылка их по сети туда-сюда. Впрочем об этом сказано достаточно
6. Загрузка-выгрузка данных из облачного сервиса (для бекапа, импорта в другую прогу) возможно только настолько, насколько её реализовали создатели сервиса. Сервис упал, закрылся, заддосен - ты соснул.
В случае же десктопной программы - всегда можно либо открыть файл сторонним софтом, либо в крайнем случае попросить знакомого программера написать парсер. Структурированные данные не потеряются.
Итого: при текущей скорости развития, веб не заменит десктоп ещё без малого 10-20 лет. А может и долше, т.к. этот процесс замедляется отсутствием качественных языков для разработки новых веб-браузеров, компиляторов, интерпретаторов (языков, которые придут на замену js).
Перспективные D, Rust, Dart etc пока лишь на подходе и когда войдут в продакшн - неизвестно.
Поэтому возникает вопрос к анону: зачем досрочно валить с десктопа, жрать веб и лишь приумножать безумный хайп непродуманности и кривости нынешнего веба?
Неужто не хватает работы? На контор, пилящих на C#/Java/C++ - полно!
Лично я остаюсь кодить на качественных, проверенных временем десктоп технологиях, чтобы, если уж случится чудо и на моём веку придёт настоящий, не дутый расцвет веба, преспокойно и вальяжно вкатиться на всё готовенькое. Ведь я ценю своё время.