Бьерн Страуструп.
Язык программирования С++
17
В проекте С++ особое внимание уделяется структурированию программы. Это вызвано увеличением
размеров программ со времени появления С. Небольшую программу (скажем, не более 1000 строк)
можно заставить из упрямства работать, нарушая все правила хорошего стиля программирования.
Однако, действуя так, человек уже не сможет справиться с большой программой. Если у вашей
программы в 10 000 строк плохая структура, то вы обнаружите, что новые ошибки появляются в ней так
же быстро, как удаляются старые. С++ создавался с целью, чтобы большую программу можно было
структурировать таким образом, чтобы одному человеку не пришлось работать с текстом в 25000 строк.
В настоящее время можно считать, что эта цель полностью достигнута.
Существуют, конечно, программы еще большего размера. Однако те из них, которые действительно
используются, обычно можно разбить на несколько практически независимых частей, каждая из которых
имеет значительно меньший упомянутого размер. Естественно, трудность написания и сопровождения
программы определяется не только числом строк текста, но и сложностью предметной области. Так что
приведенные здесь числа, которыми обосновывались наши соображения, не надо воспринимать
слишком серьезно.
К сожалению, не всякую часть программы можно хорошо структурировать, сделать независимой от
аппаратуры, достаточно понятной и т.д. В С++ есть средства, непосредственно и эффективно
представляющие аппаратные возможности. Их использование позволяет избавиться от беспокойства о
надежности и простоте понимания программы. Такие части программы можно скрывать, предоставляя
надежный и простой интерфейс с ними.
Естественно, если С++ используется для большой программы, то это означает, что язык используют
группы программистов. Полезную роль здесь сыграют свойственные языку модульность, гибкость и
строго типизированныеинтерфейсы. В С++ есть такой же хороший набор средств для создания больших
программ, как во многих языках. Но когда программа становится еще больше, проблемы по ее
созданию и сопровождению перемещаются из области языка в более глобальную область программных
средств и управления проектом. Этим вопросам посвящены главы 11 и 12.
В этой книге основное внимание уделяется методам создания универсальных средств, полезных типов,
библиотек и т.д. Эти методы можно успешно применять как для маленьких, так и для больших
программ. Более того, поскольку все нетривиальные программы состоят из нескольких в значительной
степени независимых друг от друга частей, методы программирования отдельных частей пригодятся
как системным, так и прикладным программистам.
Может возникнуть подозрение, что запись программы с использованием подробной системы типов,
увеличит размер текста. Для программы на С++ это не так: программа на С++, в которой описаны типы
формальных параметров функций, определены классы и т.п., обычно бывает даже короче своего
эквивалента на С, где эти средства не используются. Когда в программе на С++ используются
библиотеки, она также оказывается короче своего эквивалента на С, если, конечно, он существует.
Достарыңызбен бөлісу: