Архитектура Аудит Военная наука Иностранные языки Медицина Металлургия Метрология
Образование Политология Производство Психология Стандартизация Технологии


Цикл с постусловием do while



Оператор цикла do while также организует выполнение одного оператора (простого или составного) неизвестное заранее число раз. Однако в отличие от цикла while условие завершения цикла проверяется после выполнения тела цикла. Формат цикла do while:

do S while (B);

где В - выражение, истинность которого проверяется (условие завершения цикла); S - тело цикла - оператор (простой или блок).

Сначала выполняется оператор S, а затем анализируется значение выражения В: если оно истинно, то управление передается оператору S, если ложно - цикл завершается, и управление передается на оператор, следующий за условием B. Так как условие В проверяется после выполнения тела цикла, то в любом случае тело цикла выполнится хотя бы один раз.

В операторе do while, так же как и в операторе while, возможна ситуация зацикливания в случае, если условие В всегда будет оставаться истинным.

Цикл с параметром for

Цикл с параметром имеет следующую структуру:

for ( < инициализация>; < выражение>; < модификация> ) < оператор>;

Инициализация используется для объявления и/или присвоения начальных значений величинам, используемым в цикле в качестве параметров (счетчиков). В этой части можно записать несколько операторов, разделенных запятой. Областью действия переменных, объявленных в части инициализации цикла, является цикл и вложенные блоки. Инициализация выполняется один раз в начале исполнения цикла.

Выражение определяет условие выполнения цикла: если его результат истинен, цикл выполняется. Истинность выражения проверяется перед каждым выполнением тела цикла, таким образом, цикл с параметром реализован как цикл с предусловием. В блоке выражение через запятую можно записать несколько логических выражений, тогда запятая равносильна операции логическое И ( & & ).

Модификация выполняется после каждой итерации цикла и служит обычно для изменения параметров цикла. В части модификация можно записать несколько операторов через запятую.

Оператор (простой или составной) представляет собой тело цикла.

Любая из частей оператора for (инициализация, выражение, модификация, оператор) может отсутствовать, но точку с запятой, определяющую позицию пропускаемой части, надо оставить.

Пример формирования строки состоящей из чисел от 0 до 9 разделенных пробелами:

for (var i = 0; i < = 9; i++)

{

s += i + " ";

}

Данный пример работате следующим образом. Сначала вычисляется начальное значение переменной i. Затем, пока значение i меньше или равно 9, выполняется тело цикла и затем повторно вычисляется значение i. Когда значение i становится больше 9, условие становится ложным и управление передается за пределы цикла.

Средства отладки программ

Практически в каждой вновь написанной программе после запуска обнаруживаются ошибки.

Ошибки первого уровня (ошибки компиляции) связаны с неправильной записью операторов (орфографические, синтаксические). При обнаружении ошибок компилятор формирует список, который отображается по завершению компиляции (рис. 4.1.). При этом возможен только запуск программы, которая была успешно скомпилирована для предыдущей версии программы.

 

Рис. 4.1. Окно со списком ошибок компиляции.

При выявлении ошибок компиляции в нижней части экрана появляется текстовое окно (рис 4.1.), содержащее сведения обо всех ошибках, найденных в проекте. Каждая строка этого окна содержит имя файла, в котором найдена ошибка, номер строки с ошибкой и характер ошибки. Для быстрого перехода к интересующей ошибке необходимо дважды щелкнуть на строке с ее описанием. Следует обратить внимание на то, что одна ошибка может повлечь за собой другие, которые исчезнут при ее исправлении. Поэтому следует исправлять ошибки последовательно, сверху вниз и, после исправления каждой ошибки компилировать программу снова.

Ошибки второго уровня (ошибки выполнения) связаны с ошибками выбранного алгоритма решения или с неправильной программной реализацией алгоритма. Эти ошибки проявляются в том, что результат расчета оказывается неверным либо происходит переполнение, деление на ноль и др. Поэтому перед использованием отлаженной программы ее надо протестировать, т.е. сделать просчеты при таких комбинациях исходных данных, для которых заранее известен результат. Если тестовые расчеты указывают на ошибку, то для ее поиска следует использовать встроенные средства отладки среды программирования.

В простейшем случае для локализации места ошибки рекомендуется поступать следующим образом. В окне редактирования текста установить точку останова перед подозрительным участком, которая позволит остановить выполнение программы и далее более детально следить за ходом работы операторов и изменением значений паерменных. Для этого достаточно в окне редактирования кода щелкнуть слева от нужной строки. В результате чего данная строка быдет выделена красным (рис. 4.2.).

Рис. 4.2. Фрагмент кода с точкой останова

 

При выполнении программы и достижения установленной точки, программа будет остановлена и далее можно будет выполнять код по операторно с помощью кнопок F10 (без захода в подпрограммы) или F11 (с заходом в подпрограммы) (рис 4.3.).

 

Рис. 4.3. Отладка программы

Желтым выделяется оператор, который будет выполнен. Значение переменных во время выполнения можно увидеть наведя на них курсор. Для снятия программы с выполнения необходимо нажать Shift F5.

Для поиска алгоритмических ошибок контролуются значения промежуточных переменных на каждом шаге выполнения подозрительного кода и сравниваются с результатами, полученными вручную.

4.3. Порядок выполнения задания

Задание: Вычислим и выведем на экран таблицу значений функции y=a•lnx при x, изменяющемся от x0 до xk с шагом dx, a - константа.

Панель диалога представлена на рис 4.4.

 

Рис. 4.4. Окно программы для табулирования функции.

 

Текст обработчика нажатия кнопки Вычислить приведен ниже.

 

private void button1_Click(object sender, EventArgs e)

{

// Считывание начальных данных

double x0 = Convert.ToDouble(textBox1.Text);

double xk = Convert.ToDouble(textBox2.Text);

double dx = Convert.ToDouble(textBox3.Text);

double a = Convert.ToDouble(textBox4.Text);

textBox5.Text = " Работу выполнил ст. Иванов М.А." + Environment.NewLine;

// Цикл для табулирования функции

double x = x0;

while (x< =(xk+dx/2))

{

double y = a*Math.Log(x);

textBox5.Text += " x=" + Convert.ToString(x) +

"; y=" + Convert.ToString(y) + Environment.NewLine;

x = x + dx;

}

После отладки программы составьте тест (X0=2, Xk=4, Dx=0, 2), установите точку останова на оператор перед циклом и запустите программу в отладочном режиме (F5). После попадания на точку остановки, нажимая клавишу F10, выполните пошагово программу и проследите, как меняются все переменные в процессе выполнения.

4.4. Выполнение индивидуального задания

По указанию преподавателя выберите нужный вариант задачи из нижеприведенного списка. Откорректируйте панель диалога и текст программы.

Индивидуальные задания

Cоставить программу для табулирования функции y(x), вывести на экран значения x и y(x)

 

 

 


Поделиться:



Популярное:

  1. Антибиотики гр тетрациклина и левомицетина.
  2. В жизненном цикле багрянок имеются следующие фазы (поколения)
  3. В процессе операционного цикла
  4. Вегетативно-репродуктивный цикл и особенности рекомбинации у вирулентных фагов
  5. Виды экономических циклов и причины циклических колебаний.
  6. Виды экономических циклов. Теория длинных волн Н.Кондратьева.
  7. ВОЗМОЖНЫЕ НЕИСПРАВНОСТИ МОТОЦИКЛА И МЕТОДЫ ИХ УСТРАНЕНИЯ
  8. Вопрос 19. Определение потребности в оборотных средствах корпорации. Понятие производственного и финансового циклов.
  9. Вопрос № 18 Оценка деловой активности предприятия. Циклы деятельности предприятия.
  10. ВОСЕМНАДЦАТЬ ОСНОВНЫХ ЦИКЛОВ ИСТОРИЧЕСКОЙ ГРУППОВОЙ ФАНТАЗИИ В АМЕРИКЕ
  11. Гликолиз, суть его реакций, энергетика, синтез сахаров при обращении гликолиза; цикл ди- трикарбоновых кислот, характеристика основных стадий цикла.
  12. Города-крепости Микены и Тиринф. «Циклопическая кладка»


Последнее изменение этой страницы: 2016-04-09; Просмотров: 1113; Нарушение авторского права страницы


lektsia.com 2007 - 2024 год. Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав! (0.016 с.)
Главная | Случайная страница | Обратная связь