Сначала совсем немного официальной информации. Пару недель назад компания Google выпустила свой новый визуальный язык программирования Google Blockly, который позволяет создавать программы вообще без ввода каких-либо символов или текста. Разработка здесь осуществляется из широкого набора типовых лего-блоков, логическая композиция и соединение которых позволяет реализовывать заданную алгоритмическую функциональность программы. Технически этот визуальный язык реализован на JavaScript и позволяет составлять такие визуальные программы прямо в своем браузере, просто перетаскивая и компонуя в логические цепочки функциональные блоки, после чего такая программа может быть скомпилирована в более традиционный целевой язык, такой как JavaScript, Dart или Python. Google Blockly – это Open Source-проект, который выпущен под лицензией Apache License 2.0. Чтобы подчеркнуть то, что пока это только «демонстрация концепции и не более того», данный релиз не распространяется в традиционном виде отдельного файла (тарболла) с исходниками, а доступен лишь через синхронизацию с SVN-репозиторием разработчиков. На всякий случай также призываю не путать этот новый язык с одноименным фреймворком Blocky IO.
История языка и его концепция
Несмотря на множество самых разных версий происхождения этого очень необычного языка, возникающих у программирующей публики, сама Google категорично утверждает, что источником вдохновения для Google Blockly послужил идеологически похожий и уже весьма известный проект для платформы Android – AppInventor. Google также добавляет, что сам AppInventor, в свою очередь, был вдохновлен языком Scratch. Сейчас Scratch – это гораздо более навороченное решение, нежели Blockly. Это не только полноценный «визуальный объектно-ориентированный язык» (sic!) с элементами событийно-ориентированной логики, но и мультиплатформенное решение: его исходники доступны для Windows, Mac OS X и Linux. Несмотря на все навороты, это – язык, который чаще всего используется для обучения детей основам программирования по всему миру.
Чтобы проследить корни этой ветви глубже, отметим, что главным разработчиком Scratch являлся Массачусетский технологический институт (MIT Media Lab), в котором и были заложены основы упомянутого AppInventor'а. Существует альтернативная разработка для Scratch, которую принципиально сделал открытой Калифорнийский университет в Беркли (University of California at Berkeley) – это Snap (сейчас переименованный в Build Your Own Blocks из-за существования многочисленных проектов-синонимов для Snap: например, так же называется специализированный язык программирования радиотелескопов). Последняя версия, Snap 4, – практически полностью переработанный вариант этого языка, написанный с учетом самых современных возможностей HTML5/JavaScript.
Аналогичная разработка давно существует и на платформе Mac OS X: это язык Stencyl, который специализируется на быстром создании игровых приложений для iOS и Flash.
В целом все эти языки относятся, равно как и Google Blockly, к широкой категории Visual programming language (VPL), коих на данный момент существует уже более сотни.
Главные особенности Blockly
Но вернемся снова к нашему главному герою, разноцветному Blockly. Чтобы подчеркнуть новизну этого языка, его создатели выделяют в нём два принципиальных момента, подсвечивающих его на фоне множества других VPL-языков. Во-первых, это сильный акцент на визуальной составляющей разработки; по аналогии с высокоуровневыми языками предложено называть подобный тип языков «сильно-визуальными» (все легоподобные языки). Такой подход исключительно востребован для новых сенсорных устройств, где ввод традиционного текста затруднён, кроме того, такая форма программирования, как показывает опыт, имеет гораздо более легкий порог вхождения, в частности программы на Google Blockly составляют даже дети. С учетом самых серьёзных намерений по его развитию со стороны Google этот язык имеет очень интересные перспективы на будущее.
Второй принципиальный момент в нем – это возможность компиляции на более традиционный язык программирования на выбор, что создает условия для реализации самых разных подходов по дальнейшему программированию. Например, отдельные части программы могут очень быстро создаваться на Google Blockly, затем после компиляции, например в Python, исходный код такой программы может быть доработан уже на Python, или даже вставлен в уже готовый проект в целях его расширения. В последнем случае приводится пример возможностей расширения Gmail для создания фильтрации своих писем на Google Blockly. Google считает, что это типовой случай в современном программировании, например при написании некоего расширения для MS Office, когда 90% этого расширения – это некая «полезная логика», а 10% – просто код сопряжения этого расширения с API хост-программы. Google считает, что в таком случае очень удобно быстро «собрать» собственно прикладную логику приложения на Google Blockly, а весь более низкоуровневый код работы с API дописать уже на Python или Dart.
При этом текущее временное ограничение языка такое: он не предназначен для создания больших приложений. Пока область его применения – небольшие сервисные скрипты, содержащие сложную логику и многократно вложенные логические и циклические конструкции, которые, по мнению специалистов Google, реально проще составлять именно на сверхнаглядном Blockly. Отдельно подчеркивается, что в следующих версиях этого визуального языка планируется существенно расширить его семантику, что по заверениям Google сделает его возможности сопоставимыми с традиционными языками программирования. Отсюда важный вывод и отличие от других VPL'ов: не следует рассматривать этот язык лишь как обучающий – в будущем планируется создание полноценного мультиплатформенного языка программирования на его базе. Именно по причине будущего расширения этого языка принято решение не использовать подход упаковки логики в уже распространенные условно-символические программные схемы (data-flow metaphor languages), так как эксперименты показали, что такой устаревший способ представления тяжело поддается расширению и применим исключительно к узкоспециализированным областям программирования.
Будущее языка
Напомню, что здесь разработка осуществляется непосредственно в браузерном web-редакторе, и в процессе разработки программы её промежуточные результаты сохраняются (и вновь загружаются, если это нужно для рестарта проекта) в формате XML. Google Blockly поддерживает не только обычные циклы и ветвления, но теоретически и рекурсию.
В ближайшее время планируется реализовать: элементы отладки, поддержку мобильных устройств, работу с курсором для лучшего удобства работы, генерацию кода для устройств на базе Arduino. Будут добавлены простейшие элементы событийно-ориентированного программирования – вызов обработчиков при возникновении определенных ситуаций или при изменении статусов или переменных. В самое ближайшее время планируется существенно улучшить документацию, одновременно добавив множество новых блоков, а также реализовать возможность передачи внешних параметров в процедуры и функции. Также над логическими блоками (или сразу массивом из блоков) будет обеспечен набор стандартных операций: drag & drop, cut, copy и paste.
Один из главных разработчиков языка Нил Фрейзер (Neil Fraser) так описывает главную цель создания языка: «Эта популярная концепция прошла очень длинный путь, от «Ассемблера» к «Фортрану», затем к C++ и к Python, и, наконец, – к Blockly. Это попытка подняться на ещё более высокий уровень абстракции с каждым шагом вперед, чтобы лишить программирование кастовости и закрытости, сделать его более естественным и доступным для как можно более широкого круга лиц». В заключение этот разработчик Blockly иронично замечает, что каждому кодеру важно изначально правильно очертить сферу применения этого визуального языка и не «пытаться переписывать ядро Linux на этот новый и перспективный язык». Чуть отклоняясь от формата статьи, походу хочу обратить внимание читателя на внерабочие интересы главного разработчика Blockly, например, на разработанную им центрифугу, воспроизводящую условия гравитации Юпитера. Ответ на вопрос «зачем?» снова возвращает нас в канву нашего основного повествования: Blockly – это поиск всего нового, попытка выйти за формат всего застывшего, привычного и обыденного.
Пробуем Blockly на вкус
Сама Google предлагает всем поразмяться в языке Blockly на примере типичной задачи для событийно-ориентированного семейства языков – прохождении лабиринта, для решения которой уже развернута соответствующая рабочая web-среда. Но, прежде чем браться за лабиринт, мы в качестве исходной точки намалюем традиционное приложение ”Hello World”.
Вход в рабочую среду редактора среды разработки Blockly можно найти вот здесь. Те, кто предпочитает писать справо налево (не будем называть их вслух по политическим причинам) – ваяют свой код вот в этой политкорректной версии. Как видите, у Google Blockly с «этим» всё по-взрослому (кстати говоря, в Visual Studio сделать это не намного сложнее).
О’кей, будем считать, что, увидев привычное ”Hello World”, наша психика адаптировалась к новому языку (как минимум мы дали ей шанс), поэтому поднимаем планку выше – пишем небольшой скрипт, который распечатывает содержимое им же сгенерированного списка.
Теперь привожу уже автогенерацию этого же кода на JavaScript:
var message;
var Alist;
var x;
message = 'This is Blockly in Action';
Alist = ['Start of Alist', 66, [message.length, Math.sin(90 / 180 * Math.PI), 'End of sublist']];
window.alert(message);
for (var x_index in Alist) {
x = Alist[x_index];
window.alert(x);
}
window.alert('Thats All Folks');
А также на Python (я не привожу вариант на Dart – лично мне малоинтересный).
message = None
Alist = None
x = None
import math
message = 'This is Blockly in Action'
Alist = ['Start of Alist', 66, [len(message), math.sin(90 / 180 * Math.PI), 'End of sublist']]
print message
for x in Alist:
print x
print 'Thats All Folks'
А теперь, собственно – обещанный лабиринт, вход в который можно найти здесь. Ниже приведен листинг… эээ, изображение, наверное, так сказать правильней, моего варианта решения прохождения лабиринта. Чтобы немного усложнить себе задачу, а также из соображений самых светлых гуманистических идеалов, я поставил условие своему боту не биться головой по стенкам в поисках ходов, как это реализовано во множестве альтернативных решений, наводнивших Интернет после релиза этого языка. Вкратце – у меня нужно всегда идти по лабиринту так, чтобы правая (или левая) рука постоянно касалась стенки. Несмотря на очевидную простоту и универсальность подхода, есть и явно выраженный недостаток: это не лучшее время решения задачи (большее количество в сущности холостых итераций).
А тем, кто хочет попробовать решить эту занимательную задачку самостоятельно, я подсказываю очень удобное алгоритмическое пособие именно для оптимизации решений для подобного рода задач. Если же вам интересно глянуть и на чужие решения «проблемы лабиринта», множество конкретных примеров решений на Google Blockly можно найти здесь или здесь. И напоследок на всякий случай напоминаю, что, скорее всего, вам понадобится отключить плагины типа NoScript или AdBlock в вашем браузере, ведь при них эти браузерно-визуальные среды разработки будут работать, скорее всего, не совсем полноценно.
P.S.:
Конечно, тяжко удержаться, чтобы не заглянуть в JavaScript-код этого Maze-приложения на Blockly. Лично мне больше всего понравился вот этот милый комментарий:
/**
* Execute the user's code. Heaven help us...
*/
Примерно этого же ожидаю и я от этой новой технологии.
10 курсов по SQL для лучшего понимания работы с большими данными (май, 2023)
Собрали 10 платных и бесплатных онлайн-курсов для изучения SQL. Программы рассчитаны на слушателей, которые только начинают или продолжают знакомство с языком.
10 способов научиться программировать самостоятельно
Хотите научиться кодить и освоить алгоритмы? Собрали десять советов с чего начать изучение программирования для тех, кто только начинает своё путешествие в мир программирования и снабдили все это полезными ссылками на курсы для начинающих программистов.
10+ сертификаций Coursera, которые могут изменить вашу карьеру
Бюджетный способ прокачать навыки и повысить зарплату — это профессиональный сертификат от Google, IBM или крупного зарубежного университета. На Coursera как раз можно найти десятки полезных обучающих программ по машинному обучению, проджект-менеджменту и не только. Собрали 10+ сертификаций, которые будут выигрышно смотреться в резюме как новичка, так и опытного специалиста.
Дизайн, VR и интернет вещей: 10 доступных онлайн-курсов от Google, Amazon и других гигантов
На платформе Coursera можно найти сотни курсов от крупных корпораций, включая Google, Amazon и HubSpot. Это отличная возможность начать новую карьеру, повысить квалификацию и просто получить плюс в профессиональную карму. Мы собрали 10 программ от ИТ-компаний, которые помогут освоить машинное обучение, UX-дизайн, продакт-менеджмент, кибербезопасность и многое другое.
Хотите сообщить важную новость? Пишите в Telegram-бот
Главные события и полезные ссылки в нашем Telegram-канале
Обсуждение
Комментируйте без ограничений
Релоцировались? Теперь вы можете комментировать без верификации аккаунта.
Релоцировались? Теперь вы можете комментировать без верификации аккаунта.