Пациент, скорее, жив, чем мёртв
В начальной школе меня учили, чем живая природа отличается от неживой. Живая природа рождается, взрослеет, даёт потомство и умирает. Исходя из этого нехитрого определения, языки программирования явно относятся к живой природе. Потому что они тоже рождаются (в недрах корпораций или исследовательских групп), взрослеют (от версии к версии), дают потомство (как, например, C дал C++) и умирают. Последний этап, конечно, не сказать чтобы был особенно приятен программистам, которые программируют на умирающем языке, однако бывает, что языки программирования умирают, и происходит это, кстати, не так уж и редко.
Когда говорят об умерших языках программирования, в первую очередь, вспоминают два из них: Алгол, который стал прародителем множества современных языков, и Кобол, на котором, как говорят, было написано больше кода, чем на любом другом языке программирования. И если насчёт Алгола ни у кого уже нет сомнений в том, что этот язык программирования мёртв, то с Коболом возникают вопросы. Если уж он такой мёртвый, почему продолжают выпускаться новые версии компиляторов, сред разработки и других инструментов, нужных для программирования на нём? Действительно, определённая логика в такой постановке вопроса присутствует. И рассказ моего знакомого о том, что одна минская аутсорсинговая фирма недавно искала специалиста по Коболу, чтобы получить выгодный контракт, только подогревает интерес к этому якобы мёртвому языку.
Немного истории
Стоит, пожалуй, начать разговор об этом языке программирования с рассказа о том, как он создавался, когда и для чего. Ведь каждый язык создаётся не просто так, а для чего-то - например, Ада создавалась для программирования систем реального времени, а C# - для захвата рынка у Java.
Кобол создавался для программирования всего, что связано с бизнесом, экономикой и финансами. Даже само название, которое пишется в английском варианте как COBOL, расшифровывается как Common Business Oriented Language (язык, ориентированный на общие бизнес-задачи). Разрабатывался Кобол, по меркам компьютерного мира, не просто давно, а очень давно, и даже, пожалуй, можно сказать, очень-очень давно - первая версия этого языка программирования вышла в свет в 1959 году. И, хоть перед авторами стояла задача создать простой язык программирования, вряд ли современные программисты назовут Кобол простым и привычным. Впрочем, дело не в том, что авторы языка плохо справились со своей задачей - дело в том, что за полвека несколько изменились представления о том, что является простым языком программирования.
Тогда, в конце пятидесятых, людей, которые умели бы программировать на высокоуровневом языке, было сравнительно немного. А потому Кобол был разработан таким образом, чтобы текст программы на нём был максимально похож на текст на обычном английском. Программы на Коболе могут читать и понимать неспециалисты - по крайней мере, это сделать гораздо легче, чем с программами, написанными на многих современных языках. Если вы покажете текст программы на том же Perl'е знакомой студентке филологического факультета БГУ, она гарантированно пошлёт вас в Новинки. Если вы покажете ей программу на Коболе, то она с высокой степенью вероятности даже сможет вам рассказать, что эта самая программа делает. Сейчас, конечно, кажется несколько странным, мягко говоря, ориентировать язык для создания бизнес-приложений на непрофессионалов, но во многом, думаю, именно эта ориентация способствовала тому, что на Коболе было написано столько кода.
Что интересно, руководителем проекта по созданию Кобола была женщина - Грейс Хоппер; её часто называют бабушкой Кобола. Практически с самого своего рождения Кобол является ANSI-стандартизованным языком программирования. Всего было выпущено пять стандартов языка: COBOL-60, COBOL-68, COBOL-74, COBOL-85, COBOL 2002 (обратите внимание, что, так как название языка - это акроним, то по-английски правильно его писать большими буквами). Кстати, год принятия последнего стандарта - это ещё один довольно-таки существенный повод говорить о том, что Кобол всё-таки, скорее, жив, чем мёртв. Вряд ли бы кто-то стал выпускать обновлённый стандарт для языка программирования, который никем и нигде не используется.
Блеск и нищета Кобола
Почему же Кобол был столь популярен раньше, а теперь во всём большом городе Минске днём с огнём не сыщешь специалиста на вакансию программиста на этом языке? Этому есть несколько причин, и, как водится, одна объективней другой. Давайте посмотрим на особенности Кобола, чтобы понять, почему он был вытеснен более новыми языками.
Во-первых, Кобол стал популярен благодаря тому, что он был первым языком, поддерживавшим структурные типы данных. Пожалуй, именно это в своё время позволило довольно быстро написать огромное количество программ для банковской сферы, страховых компаний и прочих небедных отраслей. Программы эти работали и продолжают работать на мэйнфреймах, на зависть всем Алгол-программистам. Помимо поддержки структур, Кобол предлагал ещё очень привлекательные для прикладных программистов возможности. Так, например, очень хорошей для своего времени была поддержка работы с файлами, что придавало этому языку дополнительную привлекательность в глазах создателей бизнес-приложений.
Впрочем, это с лихвой перекрывалось многословностью Кобола. Программисты не очень любят многословные языки - во многом это вызвано нежеланием писать большое количество нудного, рутинного кода, а во многом ещё и тем, что языки, в которых нужно писать много слов в коде, попросту не дают рукам угнаться за мыслями. Поэтому то, что создателями Кобола первоначально воспринималось как однозначный плюс языка (то есть то, что на нём потенциально мог бы писать и тот, кто не владеет программированием), стало, скорее, минусом. По мере развития других языков программирования роль Кобола уменьшалась, и постепенно почти вся работа программистов, писавших на нём, стала сводиться к поддержке написанных когда-то кем-то программ для мэйнфреймов. Тем не менее, эта поддержка по-прежнему приносит неплохие деньги тому, кто ей занимается.
Языковые особенности
Кобол требует чёткого структурирования файлов с исходным кодом программ. Каждая из них должна состоять из четырёх частей (в терминах Кобола - разделов): раздела идентификации, раздела среды, раздела данных и раздела процедур. В разделе идентификации записывается название программы, её автор, а также различные комментарии по поводу того, что программа должна делать (и что она делает на самом деле). Раздел среды описывает периферийное оборудование, необходимое для работы программы - всё-таки не будем забывать, Кобол разрабатывался в конце пятидесятых. В разделе данных описываются типы и структуры данных, которые используются в программе (в некотором роде этот раздел - аналог раздела type из Паскаля), а в разделе процедур находится, собственно, то, что сейчас называют программным кодом, то есть, алгоритмическая часть программы. Как видите, структура программы на Коболе содержит много того, что в современных языках программирования выносится в отдельные конфигурационные файлы и, таким образом, позволяет отделить зёрна от плевел.
Приведу пример небольшой программы на Коболе, чтобы проиллюстрировать особенности этого языка. Эта программа занимается очень простым делом - считывает два числа, перемножает их и выдаёт результат на экран. Эту и другие программы можно найти по адресу www.csis.ul.ie/COBOL.
$ SET SOURCEFORMAT "FREE" IDENTIFICATION DIVISION. PROGRAM-ID. Multiplier. AUTHOR. Michael Coughlan. * Example program using ACCEPT, DISPLAY and MULTIPLY to * get two single digit numbers from the user and multiply * them together DATA DIVISION. WORKING-STORAGE SECTION. 01 Num1 PIC 9 VALUE ZEROS. 01 Num2 PIC 9 VALUE ZEROS. 01 Result PIC 99 VALUE ZEROS. PROCEDURE DIVISION. DISPLAY "Enter first number (1 digit) : " WITH NO ADVANCING. ACCEPT Num1. DISPLAY "Enter second number (1 digit) : " WITH NO ADVANCING. ACCEPT Num2. MULTIPLY Num1 BY Num2 GIVING Result. DISPLAY "Result is = ", Result. STOP RUN.
Сравните размеры кода этой программы с теми программами на C, Java или даже сравнительно многословном Pascal/Delphi, которые занимались бы тем же самым. В общем-то, действительно похоже, что у Кобола было мало шансов сохранить свою популярность рядом с этими языками. То, что на Коболе написана огромная масса кода, который сейчас нужно поддерживать, не вызывает удивления - если уж программа, перемножающая два числа, занимает минимум 20 (!) строк кода, то просто страшно представить объём кода какого-нибудь серьёзного приложения.
Среди языковых особенностей Кобола, которые могли бы показаться странными современным программистам, стоит отметить, в первую очередь, огромное количество зарезервированных слов - порядка четырёх сотен. Ни в одном современном языке программирования, даже в Аде, нет такого количества зарезервированных слов. Первая версия Кобола не включала поддержку многих приёмов программирования, без которых сейчас крайне сложно обойтись даже при разработке простых программ. В этот список входят рекурсия, локальные переменные, динамическое распределение памяти и даже конструкции структурного программирования. Зато в первой версии стандарта Кобол была поддержка самомодифицирующегося кода (благодаря так и не прижившейся конструкции ALTER X TO PROCEED TO Y).
Кстати, именно с Коболом была связана так называемая "проблема 2000", которая волновала многие светлые умы в 1999-м и предыдущие ему годы и послужила сюжетом для фильмов, которые сегодня невозможно смотреть без улыбки.
Резюме
Конечно, то, что Кобол не умер, ещё не делает его хорошим в современных условиях языком программирования. То, что для него есть собственная надстройка для Eclipse, ещё не значит, что он столь же перспективен, как и Java, а то, что IBM выпускает для него новые версии компиляторов, не означает, что на нём будут писаться новые программы. Кобол, безусловно, скорее, жив, чем мёртв, но хорошей эту жизнь не назовёшь. Так что если вы решили изучить Кобол, то, конечно, не моё дело вас отговаривать, но, на мой взгляд, есть языки программирования (и их немало), изучать которые было бы, скажем так, разумнее.
Если же смотреть на Кобол в историческом аспекте, то это, безусловно, великий язык программирования. Фактически, это первый коммерчески успешный язык программирования, созданный не для академических, а для прикладных задач. Сложно переоценить идею структурных типов данных - фактически, благодаря ей и родилась такая парадигма, как объектно-ориентированное программирование. Так что, хотя Кобол и кажется несколько странноватым с позиции сегодняшних реалий индустрии создания программного обеспечения, это ни в коей мере не умаляет его исторического значения.
Вадим СТАНКЕВИЧ
Горячие темы