ОБЩИЕ ПРИНЦИПЫ ПОСТРОЕНИЯ ПРОГРАММ
Принципы разработки Паскаль-программы должны обеспечивать прежде всего хорошее качество обработки информации, под которым будем понимать: 1. обеспечение заданной точности расчетов при высокой скорости вычислений (см. пояснения ниже); 2. представление результатов работы программы в виде, удобном для пользователя, например, в виде графика или диаграммы вместо таблицы; 3. представление не только окончательного результата решения задачи, но и выдачи по запросу пользователя некоторых промежуточных расчетов и другой информации, дающей представление о пошаговом процессе обработки данных, необходимых для проверки корректности решения; 4. удобство эксплуатации программы и возможность внесения изменений программы (развития программы в процессе ее эксплуатации) не только разработчиком, но и пользователем (открытость программы для совершенствования). Перечисленные выше требования нельзя понимать однозначно и определенно для любой программы, так как набор требований к программе зависит прежде всего от области применения и от класса решаемых задач. Так, при решении большинства экономических задач проблем обеспечения заданной точности, как правило, не возникает. И вычислительная сложность экономических программ (под вычислительной сложностью программы будем понимать количество операций, выполняемых процессором при решении задачи. Набор этих операций (см. стр.5) может быть различным и зависит как от класса решаемых задач (задачи математической физики, прогнозирование погоды, поиск информации в базе данных по запросу пользователя и т.д.), так и от метода решения и даже от квалификации программиста. При этом следует иметь ввиду, что логические операции наименее трудоемки, арифметические более трудоемкие, из них деление требует существенно больше процессорного времени, чем умножение, поэтому, например, для повышения скорости выполнения программы желательно записать Z*0.5 вместо Z/2) обычно невелика. При огромных объемах информации в памяти компьютера в виде базы данных, при частых обращениях пользователей к базе данных, при запросах на ввод новой информации и на формирование выходных документов основная нагрузка здесь ложится на процессы обмена данными между различными уровнями памяти (оперативной, дисковой,…) и на внешние устройства. Проблема обеспечения точности может возникать скорее всего не в сфере вычисления (современные процессоры позволяют вычислять с любой практически необходимой точностью, задавая соответствующие типы числовых переменных и студенту важно понять, следует ли задавать избыточную точность, представляя, например данные типом LongInt вместо integer или даже shortint, о типах данных см. 6.4), а в точности описания программируемого процесса или в точности (адекватности) отображения процесса или объекта заданным набором параметров. Кроме этого, разработчику программы следует стремиться создавать программы, которые обладали бы такими свойствами как: максимальная дружественность диалога пользователя с программой, которая обеспечивается благодаря наличию в программе операторов, формирующих подсказки пользователю; компактность и наглядность основной программы, которые достигаются: 1. выделением из основной программы процедур и функций; 2. применением модулей; 3. применением механизма рекурсий как средства понижения размерности задачи (подробно об этом в [3,4]); 3. структурированность программы, которая состоит в том, что текст программы оформляется с учетом принципов структурного программирования [7]. В частности, программа делится на четкие разделы (блоки) и в ней используются средства, позволяющие читать текст программы последовательно, без возврата назад (именно с учетом этого требования в программе не рекомендуется применять оператор безусловного перехода GOTO (см. 7.3)). Текст программы должен также сопровождаться подробными комментариями.
|