Стандартный состав систем программирования

10. Понятие и структура системы программирования. История возникновения систем программирования. Структура современной системы программирования.

Всякий компилятор является составной частью системного программного печения. Основное назначение компиляторов — служить для разработки прикладных и системных программ с помощью языков высокого уровня. Любая программа, как системная, так и прикладная, проходит этапы жизш цикла, начиная от проектирования и вплоть до внедрения и сопровожден] 25, 43]. А компиляторы — это средства, служащие для создания програм обеспечения на этапах кодирования, тестирования и отладки. Однако сам по себе компилятор не решает полностью всех задач, связ с разработкой новой программы. Средств только лишь компилятора недос но для того, чтобы обеспечить прохождение программой указанных этапо ненного цикла. Поэтому компиляторы — это программное обеспечение, к< функционирует в тесном взаимодействии с другими техническими среде применяемыми на данных этапах.

Основные технические средства, используемые в комплексе с компилят включают в себя следующие программные модули:

  • текстовые редакторы, служащие для создания текстов исходных прогр
  • компоновщики, позволяющие объединять несколько объектных модул рождаемых компилятором, в единое целое;
  • библиотеки прикладных программ, содержащие в себе наиболее ча < пользуемые функции и подпрограммы в виде готовых объектных мод^

□ загрузчики, обеспечивающие подготовку готовой программы к выполнению; О отладчики, выполняющие программу в заданном режиме с целью поиска, об­наружения и локализации ошибок. Первоначально компиляторы представляли собой обособленные программные модули, решающие исключительно задачу перевода исходного текста программы на входном языке в язык машинных кодов. Компиляторы разрабатывались вне связи с другими техническими средствами, с которыми им приходилось взаимо­действовать. В задачу разработчика программы входило обеспечить взаимосвязь всех используемых технических средств:

  • подать входные данные в виде текста исходной программы на вход компиля­ тора;
  • получить от компилятора результаты его работы в виде набора объектных файлов;
  • подать весь набор полученных объектных файлов вместе с необходимыми библиотеками подпрограмм на вход компоновщику;
  • получить от компоновщика единый файл программы (исполняемый файл) и подготовить его к выполнению с помощью загрузчика;
  • поставить программу на выполнение, при необходимости использовать от­ ладчик для проверки правильности выполнения программы.

Все эти действия выполнялись с помощью последовательности команд, иници­ировавших запуск соответствующих программных модулей с передачей им всех необходимых параметров. Параметры передавались каждому модулю в команд­ной строке и представляли собой набор имен файлов и настроек, реализованных в виде специальных «ключей». Пользователи могли выполнять эти команды по­следовательно вручную, а с развитием средств командных процессоров ОС они стали объединять их в командные файлы. Со временем разработчики компиляторов постарались облегчить труд пользова­телей, предоставив им все необходимое множество программных модулей в со­ставе одной поставки компилятора. Теперь компиляторы поставлялись уже вку­пе со всеми необходимыми сопровождающими техническими средствами. Кроме того, были унифицированы форматы объектных файлов и файлов библиотек подпрограмм. Теперь разработчики, имея компилятор от одного производителя, могли в принципе пользоваться библиотеками и объектными файлами, получен­ными от другого производителя компиляторов. Для написания командных файлов компиляции был предложен специальный командный язык — язык Makefile [31, 39, 67, 68, 90]. Он позволял в достаточно гибкой и удобной форме описать весь процесс создания программы от порожде­ния исходных текстов до подготовки ее к выполнению. Это было удобное, но достаточно сложное техническое средство, требующее от разработчика высокой степени подготовки и профессиональных знаний, поскольку сам командный язык Makefile был по сложности сравним с простым языком программирования. Язык Makefile стал стандартным средством, единым для компиляторов всех раз­работчиков. Такая структура средств разработки существовала достаточно долгое время, а в некоторых случаях она используется и по сей день (особенно при создании сис­темных программ). Ее широкое распространение было связано с тем, что сама по себе вся эта структура средств разработки была очень удобной при пакетном вы­полнении программ на компьютере, что способствовало ее повсеместному при­менению в эпоху «mainframe». Следующим шагом в развитии средств разработки стало появление так называе­мой «интегрированной среды разработки». Интегрированная среда объединила в себе возможности текстовых редакторов исходных текстов программ и команд­ный язык компиляции. Пользователь (разработчик исходной программы) теперь не должен был выполнять всю последовательность действий от порождения ис­ходного кода до его выполнения, от него также не требовалось описывать этот процесс с помощью системы команд в Makefile. Теперь ему было достаточно только указать в удобной интерфейсной форме состав необходимых для созда­ния программы исходных модулей и библиотек. Ключи, необходимые компиля­тору и другим техническим средствам, также задавались в виде интерфейсных форм настройки. После этого интегрированная среда разработки сама автоматически готовила всю необходимую последовательность команд Makefile, выполняла их, получала ре­зультат и сообщала о возникших ошибках при их наличии. Причем сам текст ис­ходных модулей пользователь мог изменить здесь же, не прерывая работу с ин­тегрированной средой, чтобы потом при необходимости просто повторить весь процесс компиляции. Создание интегрированных сред разработки стало возможным благодаря бурно­му развитию персональных компьютеров и появлению развитых средств интер­фейса пользователя (сначала текстовых, а потом и графических). Их появление на рынке определило дальнейшие развитие такого рода технических средств. Пожалуй, первой удачной средой такого рода можно признать интегрированную среду программирования Turbo Pascal на основе языка Pascal производства фир­мы Borland [34, 71, 72, 98]. Ее широкая популярность определила тот факт, что со временем все разработчики компиляторов обратились к созданию интегриро­ванных средств разработки для своих продуктов. Развитие интегрированных сред несколько снизило требования к профессио­нальным навыкам разработчиков исходных программ. Теперь в простейшем слу­чае от разработчика требовалось только знание исходного языка (его синтаксиса и семантики). При создании прикладной программы ее разработчик мог в про­стейшем случае даже не разбираться в архитектуре целевой вычислительной системы. Дальнейшее развитие средств разработки также тесно связано с повсеместным распространением развитых средств графического интерфейса пользователя. Та­кой интерфейс стал неотъемлемой составной частью многих современных ОС и так называемых графических оболочек [35, 71]. Со временем он стал стандар­том «де-факто» практически во всех современных прикладных программах. Это не могло не сказаться на требованиях, предъявляемым к средствам разра­ботки программного обеспечения. В их состав были сначала включены соответ- ствующие библиотеки, обеспечивающие поддержку развитого графического ин­терфейса пользователя и взаимодействие с функциями API (application program interface, прикладной программный интерфейс) операционных систем. А затем для работы с ними потребовались дополнительные средства, обеспечивающие разработку внешнего вида интерфейсных модулей. Такая работа была уже более характерна для дизайнера, чем для программиста. Для описания графических элементов программ потребовались соответствую­щие языки. На их основе сложилось понятие «ресурсов» (resources) 1 приклад­ных программ. Ресурсами прикладной программы будем называть множество данных, обеспечи­вающих внешний вид интерфейса пользователя этой программы и не связанных напрямую с логикой выполнения программы. Характерными примерами ресур­сов являются: тексты сообщений, выдаваемых программой; цветовая гамма эле­ментов интерфейса; надписи на таких элементах, как кнопки и заголовки окон и т. п. Для формирования структуры ресурсов, в свою очередь, потребовались редакто­ры ресурсов, а затем и компиляторы ресурсов, обрабатывающие результат их ра­боты 2 . Ресурсы, полученные с выхода компиляторов ресурсов, стали обрабаты­ваться компоновщиками и загрузчиками. Весь этот комплекс программно-технических средств в настоящие время состав­ляет новое понятие, которое здесь названо «системой программирования». Структура современной системы программированияСистемой программирования будем называть весь комплекс программных средств, предназначенных для кодирования, тестирования и отладки программного обес­печения. Нередко системы программирования взаимосвязаны и с другими тех­ническими средствами, служащими целям создания программного обеспечения на более ранних этапах жизненного цикла (от формулировки требований и ана­лиза до проектирования). Однако рассмотрение таких систем выходит за рамки данного учебного пособия. Системы программирования в современном мире доминируют на рынке средств разработки. Практически все фирмы-разработчики компиляторов поставляют свои продукты в составе соответствующей системы программирования в комплексе всех прочих технических средств. Отдельные компиляторы являются редкостью и, как правило, служат только узко специализированным целям. На рис. 15.1 приведена общая структура современной системы программирова­ния. На ней выделены все основные составляющие современной системы про­граммирования и их взаимосвязь. Отдельные составляющие разбиты по группам в соответствии с этапами развития средств разработки. Эти группы отражают все этапы развития от отдельных программных компонентов до цельной систе­мы программирования. Зэтап/’Исходный^. !„! /’PecvDcyN* ‘‘ кппV^КомпиляторугесУРсыl;>К0Л■ ресурсов | ‘.интерфейса,’-^ Загрузчик код ^ресурсов,’ Редактор;ресурсов |(интерфейсных!форм) | Выполнение Рис. 15.1. Общая структура и этапы развития систем программирования Из рис. 15.1 видно, что современная система программирования — это достаточ­но сложный комплекс различных программно-технических средств. Все они слу­жат цели создания прикладного и системного программного обеспечения. Тенденция такова, что все развитие систем программирования идет в направле­нии неуклонного повышения их дружественности и сервисных возможностей. Это связано с тем, что на рынке в первую очередь лидируют те системы програм­мирования, которые позволяют существенно снизить трудозатраты, потребные для создания программного обеспечения на этапах жизненного цикла, связан­ных с кодированием, тестированием и отладкой программ. Показатель снижения трудозатрат в настоящее время считается более существенным, чем показатели, определяющие эффективность результирующей программы, построенной с по­мощью системы программирования. В качестве основных тенденций в развитии современных систем программиро­вания следует указать внедрение в них средств разработки на основе так назы­ваемых «языков четвертого поколения» — 4GL (four generation languages), — а также поддержка систем «быстрой разработки программного обеспечения» — RAD (rapid application development). Языки четвертого поколения — 4GL — представляют собой широкий набор средств, ориентированных на проектирование и разработку программного обеспечения. Они строятся на основе оперирования не синтаксическими структурами языка и описаниями элементов интерфейса, а представляющими их графическими об­разами. На таком уровне проектировать и разрабатывать прикладное программ­ное обеспечение может пользователь, не являющийся квалифицированным про­граммистом, зато имеющий представление о предметной области, на работу в которой ориентирована прикладная программа. Языки четвертого поколения яв­ляются следующим (четвертым по счету) этапом в развитии систем программи­рования. Описание программы, построенное на основе языков 4GL, транслируется затем в исходный текст и файл описания ресурсов интерфейса, представляющие со­бой обычный текст на соответствующем входном языке высокого уровня. С этим текстом уже может работать профессиональный программист-разработчик — он может корректировать и дополнять его необходимыми функциями. Дальнейший ход создания программного обеспечения идет уже традиционным путем, как это показано на рис. 15.1. Такой подход позволяет разделить работу проектировщика, ответственного за общую концепцию всего проекта создаваемой системы, дизайнера, отвечающего за внешний вид интерфейса пользователя, и профессионального программис­та, отвечающего непосредственно за создание исходного кода создаваемого про­граммного обеспечения. В целом языки четвертого поколения решают уже более широкий класс задач, чем традиционные системы программирования. Они составляют часть средств автоматизированного проектирования и разработки программного обеспечения, поддерживающих все этапы жизненного цикла — CASE-систем. Их рассмотре­ние выходит за рамки данного учебного пособия. Более подробную информацию о языках 4GL, технологии RAD и CASE-систе-мах в целом можно получить в [35, 43].

Читайте также:  Гуап программирование проходной балл

Источник

Оцените статью