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.
Немного неясно из вашей постановки задачи, какая сторона обновляет массив?
Обсуждают сегодня