while (!isCancelled())
{
if(_custom_event.tryWait(400))
{
...
}
}
}
какой сакральный смысл в tryWait ?
2. задача - обновлять массив, к которому идут обращения в реалтайме.
устанавливается флаг isUpdate и проверяется при каждой попытке чтения , т.е. если флаг true, то получаем безопасное обновление, но недоступность информации на несколько секунд
есть ли способы сделать обновление без лишней проверки, безопасно и с минимумом простоя?
2) почему это не даблбуффер? Они большие?
откуда я знаю почему))) потому и спрашиваю, как можно ещё сделать 👀 туда загружаются файлы ~15-30Мб, ОЗУ не проблема
Shared cow_cache ptr + atomic version. Периодически чекать версию и копировать. Копировать ptr, с mtx ессно.
При обновлении создавать новую копию и просто атомарно свапнуть указатели?
Спрйлер: любое решение этой штуки сделает очередь в том или ином виде
Не, атомарно не свопнуть конечно. Но создать новую версию, обновить через mutex public ptr и инкрементировать версию.
А потом копировать весь массив on write?
А почему не свапнуть?
Потому что нет atomic операций над shared ptr.
Немного неясно из вашей постановки задачи, какая сторона обновляет массив?
Обсуждают сегодня