Абрам Фёдорович кивает, хотя вижу, что я его окончательно не убедил. Как бы не вдарились советские учёные в грех «мелких улучшений». Буду пресекать в меру сил и возможностей.
Собрав обратно системник, я рассказал ему про схему с распознаванием заполненных стандартизированных форм, придуманных мной для ввода данных в ПК.
***
Возвращаемся ко мне в кабинет. Перед мной окна запущенного Лазаруса. Рядом сидит тот, кто будет руководить проектом СССР, дальней целью которого видится мне выпуск среди родных берёз компов, способных «тянуть» запуск программ, подобных данной среде программирования.
- Понимаете, Абрам Фёдорович, между вот этой комфортной, такой мне милой, привычной и уютненькой системой быстрой разработки приложений… т.е. других программ любого предназначения, и тем, что будет «вначале», лежат не только годы и даже десятилетия прогресса во многих отраслях и больших и ресурсозатратных научных исследований. Здесь - ещё несколько слоёв абстракций, позволявших тому не бесталанному, уж простите за похвальбу себя самого, и настырному молокососу, ловящему кайф от программирования и разработки игр, приходить после школы домой и чуть не «одной левой» - шутка конечно, сидеть и разрабатывать со скоростью три штучки в год казуальных игр, приносившие доход на 3 средних зарплаты в нашей стране после 2010 года. Но это я малость отвлёкся…
- Вы не могли бы немного расшифровать слова «слои абстракций», Никита Егорович?
Иоффе терпеливо сносит мой рваный, далёкий от академического стиля изложения рассказ и аккуратно возвращает к теме.
Он прав.
- Слои абстракций? Вот под этим определением я понимаю, что собственно программирование, с каждым, наверное, десятилетием, уходит дальше от пресловутого «железа» и приближается к более близкой человеку речи. То, о чём мечтали на эпохе первых ЭВМ, но поезд, как говорится, «всё ещё в пути». Вот смотрите, на самом низком уровне, существует так называемый микрокод. Я достаточно слабо понимаю, что это такое, всего то читал пару статей, но он есть… будет. С высокой долей уверенностью могу сказать, - это те реализуемые на аппаратном уровне состояния элементов внутри процессоров, которые собственно позволяют выполнять так называемый машинный код. Ну или нечто аналогичное на том, уровне, который соответствует первым ЭВМ. Хоть ламповым, хоть уже на полупроводниковой элементной базе.
- Не совсем понимаю, если честно, о чём вы…
Чешу репу. Задумываюсь. Эх. Рано, рано, схватился показывать Лазарус. Между нами лежат поколения ЭВМ. Но я всё же попробую. Сегодня же, но позже. А пока начинаю, тщательно конструируя фразы, излагать те немногие подробности, которые мне известны об эпохе первых «процев»
- Вот помните, те моменты из учебника, где рассматривались регистры и АЛУ?
- Теоретически я разобрался… - на мой взгляд достаточно неуверенно сообщает академик.
Пришло время накачанных в своё время материалов по эмуляции компьютерных железок 70-80-90 х. Демонстрирую на экране ноута список команд ассемблера Z80 и… фантастическую, 50 мегабайтную фотографию его самого! В своё время (воля Силы из Звёздных войн, не иначе, хаха!), высмотренную на англоязычной странице википедии - очень надеюсь, что фотка пригодится, вот прямо после разговора заставлю сержантов зафоткать, чтобы все подробности вышли! Чего раньше не подумал, это ведь такой чит-бонус! Я очень надеюсь, что эта фотография, через несколько лет, скажет специалистам намного больше, чем мне…
После рассмотрения 8-битной легенды с несколькими тысяч транзисторов «на борту», продолжаю серьёзно:
- Вот следующий уровень абстракций. Язык ассемблера и соответствующие им машинные коды.
Тыкаю пальцем в простейшие и взятые в качестве примера команды:
LD A,B
ADD A,B
Делаю рисунки на листочках, разъясняющие материал на экране.
Условные, мнемонические обозначения операций загрузки байта из регистра B в регистр A и, во втором случае - сложение A с B, с записью результата в A. И показываю тот соответствующий данным условным обозначениям машинный код.
Вставляю необходимые слова об имеющемся счётчике, указывающим на адрес в памяти следующих машинных кодов следующей команды процессора. И дополняю упоминанием о шестнадцатиричной системы счисления, жёстко-привычной «настоящим программистам» времён «только ассемблер, только хардкор!».
- То, что я обозначаю как микрокод, это и есть набор базовых команд, потребных, например на то, чтобы выполнилась какая-то операция, являющаяся стандартной, например, та же операция сложения. Т.е. какие-то там внутренние манипуляции типа подключить первый и второй регистры к выходу такому-то АЛУ. АЛУ проводит операцию, пишется результат в первый регистр, что-то ещё типа флагов, обнулений… это очень смутно мне знакомо. Извините, без подробностей. Счастье, что я вообще даже про это знаю! С точки зрения программиста, работавшего в прошлые для меня десятилетия на самом нижнем уровне, про весь этот микрокод он даже не думал, его создавали разработчики самих процессоров и он выполняется внутри того, программист лишь должен записать пару символов машинного кода или команды на ассемблере, который позже будет переведён в машинный код. Резюмируя, вот уровни абстракций: микрокод -› машинный код -› ассемблер. На котором, собственно и создавались тогда прикладные программы. Обозначения ассемблера переводились специальной программой с тем же именем в исполняемый машинный код. Вот таков тот уровень из первых процессоров 70-80-х, который, по счастью, мне знаком потому, что интересовался так называемыми вопросами эмуляции - способа запускать за счёт большего быстродействия более современной техники программы от старых компов абсолютно разных платформ. По причине, как правило связанным с детской ностальгией и любимыми компьютерными игрушками детства. У меня - с того собственно и началось - с отцовских воспоминаний о ВУЗ-е и демонстрации валявшегося в квартирной кладовке его первого личного компьютера из начала 90-х. Как раз на основе такого процессора Z80! Папаня так смачно и завлекательно делился воспоминаниями и рассказывал о тех временах начала всеобщей компьютеризации, что я «подсел на тему» и углубился в неё. Но, в общем, разрыв поколений, всё равно огромен. Я даже не знаю, по какому пути идти - сразу СССР должен заняться реализацией ЭВМ на полупроводниковой базе, после прояснения вопроса с созданием транзисторов. Или на лампах что-то в начале конструировать…
Академик, судя по появившейся на лице понимающей улыбке и некоему радостному оживлению, наконец, вникает, о чём я толковал и причём тут регистры, что такое машинный код и что такое микрокод. Изучение материала учебника было дополнено моими пояснениями и сложилось в более-менее логичную картинку?
Фух, хотя бы в первом приближении, первом человеку тут, в 1940, объяснил. Ну, я старался. Как мог. Главное, что академик - не только из тех, «кто командует», но и из тех кто будет ответственен за появление «советских компов». Продолжаю речь:
- В мое время на уровень ассемблера 99,99% программистов вообще не спускается. Не нужно. Только у кого специфические, редкие потребности и редкие особенные платформы. Медленная скорость разработки и отладки программ на нём, и современные оптимизирующие компиляторы языков программирования так называемого высокого уровня дают прекрасный по быстродействию машинный код. Теперь, Абрам Фёдорович, самое время прыгнуть наверх, в 21-й век.
Разворачиваю временно свёрнутый Лазарус и начинаю толкать речь об зарождении языков программирования, по быстрому съезжая на свой любимый Паскаль. Простите, оставшиеся в 21 веке любители C, C++ и C# и Java! Вас не забуду, но и не упомяну в первых речах. Хотя бы потому, что мои познания в предметах вашего обожания меньше. И предпочтение - иное.
Произношу положенные слова об процедурном программировании и событийной модели. Лишь вкратце упоминаю объектно-ориентированное программирование - ни к чему снова сразу «грузить им» академика. На будущих первых ЭВМ до ООП - световые:-) годы. О той процессорной мощи и объемах памяти, позволяющей играться с тысячами объектов, только мечтать… ну, или глядя на два ПК из 21 века, облизываться:-) В общем, пока структурно-процедурное программирование. Только оно. Причём все начнут в машинных кодах:-)