WikiDer > Циклический исполнительный
А циклический исполнитель[1][2] это альтернатива операционная система реального времени. Это форма совместная многозадачность, в котором есть только один задача. Единственная задача обычно реализуется как бесконечный цикл в main (), например в C.
Основная схема состоит в том, чтобы циклически повторять повторяющуюся последовательность действий с заданной частотой (также известный как циклический исполнительный механизм, запускаемый по времени). Например, рассмотрим пример Встроенная система предназначен для мониторинга Датчик температуры и обновить ЖК-дисплей отображать. На ЖК-дисплее может потребоваться запись двадцать раз в секунду (т.е. каждые 50 мс). Если датчик температуры должен считываться каждые 100 мс по другим причинам, мы могли бы построить цикл следующего вида:
int главный(пустота){ пока (1) { // Этот цикл рассчитан на 100 мс, что означает // все шаги в сумме составляют 100 мс. // Поскольку это демонстрационный код, и мы не знаем, сколько времени // tempRead или lcdWrite выполняются, мы предполагаем // они занимают нулевое время. // В результате задержки отвечают за планирование / время выполнения задачи. // Считываем температуру один раз за цикл (каждые 100 мс) currTemp = tempRead(); // Запись на ЖК-дисплей дважды за цикл (каждые 50 мс) lcdWrite(currTemp); задерживать(50); lcdWrite(currTemp); задерживать(50); // Теперь 100 мс (delay (50) + delay (50) + tempRead + lcdWrite + lcdWrite) // прошел, поэтому повторяем цикл. }}
Внешний цикл 100 мс называется основным циклом. В этом случае также имеется внутренний второстепенный цикл продолжительностью 50 мс. В этом первом примере сравнение внешнего и внутреннего циклов неочевидно. Мы можем использовать счетный механизм, чтобы уточнить основные и второстепенные циклы.
int главный(пустота){ int я == 0; пока (1) { // Этот цикл рассчитан на 50 мс. // Поскольку это демонстрационный код, и мы не знаем, сколько времени // tempRead или lcdWrite выполняются, мы предполагаем // они занимают нулевое время. // Поскольку мы хотим, чтобы tempRead выполнялся каждые 100 мс, мы используем // оператор if для проверки четности или нечетности счетчика, // и решаем, выполнять ли tempRead. // Считываем температуру каждый второй цикл (каждые 100 мс) если ( (я%2) == 0) { currTemp = tempRead(); } // Запись на ЖК-дисплей один раз за цикл (каждые 50 мс) lcdWrite(currTemp); задерживать(50); я++; // Теперь прошло 50 мс, поэтому повторяем цикл. }}
Смотрите также
- Ардуино - популярный пример этой парадигмы
- Цикл событий
- Вытеснение (вычисление)
Рекомендации
- ^ Брюс Пауэлл Дуглас (2003). Шаблоны проектирования в реальном времени: надежная масштабируемая архитектура для систем реального времени. Эддисон-Уэсли Лонгман Паблишинг Ко., Инк., Стр. 232–237. ISBN 0201699567.
- ^ Laplante, Phillip A .; Оваска, Сеппо Дж. (2012). Проектирование и анализ систем в реальном времени (4-е изд.). Хобокен, Нью-Джерси: John Wiley & Sons, Inc., стр. 84–85, 100–102. ISBN 978-0-470-76864-8.