- Условный переход
-
Условный переход — команда программируемому вычислительному устройству на изменение порядка выполнения программы в соответствии с результатом проверки некоторого условия.
Наиболее часто условный переход имеет две стадии: на первой происходит сравнение между собой некоторых величин, определяющих условие перехода, на второй выполняется сам переход.
Необходимость корректной обработки условных переходов накладывает серьёзный отпечаток на логику работы современных конвейерных процессоров. Условные переходы могут выполняться двумя способами. Выполняемые условные переходы меняют значение счётчика команд процессора на вычисленное значение адреса перехода. Невыполняемые — прибавляют к значению счётчика команд число, равное длине текущей команды в байтах, для перехода к выполнению следующей команды. Неправильное определение типа условного перехода может приводить к возникновению существенных задержек в работе конвейера и соответственно к большой потери производительности компьютера.
Примеры
В Turbo Pascal
label L; begin <тело программы> goto L; //какой-то код L: //и дальше остальная программа. end;
В С++
#include <iostream> int main() { int i; std::cout<<"Введите целое число"<<std::endl; std::cin>>i; std::cout<<"Вы ввели "; if (i >= 0) { // Проверка условия // Действия производимые, если условие выполнено std::cout<<"положительное "; } else { // Действия производимые, если условие не выполнено std::cout<<"отрицательное "; } std::cout<<"число"<<std::endl; return 0; }
Категории:- Алгоритмы
- Концепции языков программирования
Wikimedia Foundation. 2010.