Виталий Ткаченко - Обратные вызовы в C++

Здесь есть возможность читать онлайн «Виталий Ткаченко - Обратные вызовы в C++» весь текст электронной книги совершенно бесплатно (целиком полную версию без сокращений). В некоторых случаях можно слушать аудио, скачать через торрент в формате fb2 и присутствует краткое содержание. Год выпуска: 2021, Издательство: Array SelfPub.ru, Жанр: Программирование, на русском языке. Описание произведения, (предисловие) а так же отзывы посетителей доступны на портале библиотеки ЛибКат.

Обратные вызовы в C++: краткое содержание, описание и аннотация

Предлагаем к чтению аннотацию, описание, краткое содержание или предисловие (зависит от того, что написал сам автор книги «Обратные вызовы в C++»). Если вы не нашли необходимую информацию о книге — напишите в комментариях, мы постараемся отыскать её.

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

Обратные вызовы в C++ — читать онлайн бесплатно полную книгу (весь текст) целиком

Ниже представлен текст книги, разбитый по страницам. Система сохранения места последней прочитанной страницы, позволяет с удобством читать онлайн бесплатно книгу «Обратные вызовы в C++», без необходимости каждый раз заново искать на чём Вы остановились. Поставьте закладку, и сможете в любой момент перейти на страницу, на которой закончили чтение.

Тёмная тема
Сбросить

Интервал:

Закладка:

Сделать

SensorValue alertValue;

AlertRule alertRule;

SensorPointer sensor;

CheckAlertTimeout checkTimeout;

CheckAlertTimeout currentTimeout;

};

std::map containerAlert; // (6)

std::thread pollThread_; // (7)

bool exit_; // (8)

std::mutex mutex_; // (9)

void poll(); // (10)

};

В строке 1 объявлен метод для запуска процесса отслеживания пороговых значений, в строке 2 – метод для останова. Метод в строке 3 добавляет датчик для отслеживания, метод 4 – удаляет.

В строке 5 объявлена структура, в которой хранятся данные, необходимые для отслеживания показаний датчика. В строке 6 объявлен контейнер для хранения указанных структур; метод addAlertдобавляет запись в контейнер, метод deleteAlertудаляет ее. В строке 7 объявлен класс для запуска потока для отслеживания, в строке 8 объявлен индикатор выхода, в строке 9 объявлен мьютекс для синхронизации.

Отслеживание показаний реализовано в методе, объявленном в строке 10. Поток отслеживания вызывает этот метод, который циклически опрашивает назначенные датчики и в случае превышения пороговых значений осуществляет обратный вызов. Реализация приведена в Листинг 96.

Листинг 96. Отслеживание пороговых значений

void Observer::poll()

{

using namespace std::chrono_literals;

while (!exit_) // (1)

{

std::this_thread::sleep_for(1s); // (2)

std::lock_guard lock(mutex_); // (3)

for (auto& item : containerAlert) // (4)

{

Alert& alert = item.second;

alert.currentTimeout++; // (5)

if (alert.checkTimeout != 0 && alert.currentTimeout >= alert.checkTimeout) // (6)

{

bool triggerAlert = false;

if (alert.alertRule == AlertRule::More) // (7)

{

triggerAlert = alert.sensor->getValue() > alert.alertValue;

}

else // (8)

{

triggerAlert = alert.sensor->getValue() < alert.alertValue;

}

if (triggerAlert) // (9)

{

alert.checkTimeout = alert.callback(item.first, alert.alertValue); // (10)

}

alert.currentTimeout = 0; // (11)

}

}

}

}

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

В строке 4 осуществляется опрос элементов, хранящихся в контейнере. Текущее время опроса в строке 5 увеличивается на единицу. Если уведомление разрешено, о чем говорит ненулевое значение timeout, и время последнего опроса превысило назначенное время (строка 6), то тогда проверяется, имелось ли превышение пороговых значений в соответствии с назначенными правилами (строки 6, 7). Если превышение зафиксировано (строка 9), то осуществляется обратный вызов (строка 10). Этот вызов возвращает следующий интервал опроса, после чего текущее время сбрасывается (строка 11).

6.2.8. Интерфейсный класс

Класс, объявляющий интерфейс для взаимодействия с приложением, представлен в Листинг 97.

Листинг 97. Интерфейсный класс (ControlInterface.h)

namespace sensor

{

class ISensorControl

{

public:

virtual ~ ISensorControl () = default;

virtual void initialize() = 0; // (1)

virtual void shutDown() = 0; // (2)

virtual void assignDriver(DriverPointer driver) = 0; // (3)

virtual DriverPointer getAssignedDriver() = 0; // (4)

virtual DriverPointer getSensorDriver(SensorNumber number) = 0; // (5)

virtual void addSensor(SensorType type, SensorNumber number) = 0; // (6)

virtual void deleteSensor(SensorNumber number) = 0; // (7)

virtual bool isSensorExist(SensorNumber number) = 0; // (8)

virtual bool isSensorOperable(SensorNumber number) = 0; // (9)

virtual SensorValue getSensorValue(SensorNumber number) = 0; // (10)

virtual void querySensorValue(SensorNumber number, SensorValueCallback callback) = 0; // (11)

virtual void readSensorValues(SensorValueCallback callback) = 0; // (12)

virtual SensorValue getMinValue(SensorNumber first, SensorNumber last) = 0; // (13)

virtual SensorValue getMaxValue(SensorNumber first, SensorNumber last) = 0; // (14)

virtual void setAlert(SensorNumber number, SensorAlertCallback callback, SensorValue alertValue, AlertRule alertRule, CheckAlertTimeout checkTimeoutSeс = 1) = 0; // (15)

virtual void resetAlert(SensorNumber number) = 0; // (16)

static ISensorControl* createControl(); // (17)

};

};

В строке 1 и 2 объявлены методы для запуска и останова. В строках 3 и 4 объявлены методы для назначения и получения драйвера. Этот драйвер должен быть создан и назначен в самом начале работы, поскольку он будет передаваться новым создаваемым датчикам. Узнать назначенный драйвер для соответствующего датчика можно в методе 5.

В строках 6 и 7 объявлены методы для добавления и удаления датчика. В методе 8 можно проверить, существует ли датчик с переданным номером, в методе 9 можно проверить, является ли датчик работоспособным.

Читать дальше
Тёмная тема
Сбросить

Интервал:

Закладка:

Сделать

Похожие книги на «Обратные вызовы в C++»

Представляем Вашему вниманию похожие книги на «Обратные вызовы в C++» списком для выбора. Мы отобрали схожую по названию и смыслу литературу в надежде предоставить читателям больше вариантов отыскать новые, интересные, ещё непрочитанные произведения.


Отзывы о книге «Обратные вызовы в C++»

Обсуждение, отзывы о книге «Обратные вызовы в C++» и просто собственные мнения читателей. Оставьте ваши комментарии, напишите, что Вы думаете о произведении, его смысле или главных героях. Укажите что конкретно понравилось, а что нет, и почему Вы так считаете.

x