задач
while (std::lock_guard<std::mutex>(jobs_mtx_), !jobs_.empty()) {...} ? Только вот... удобно ли этот однострочник читать?
Ну, и вообще, этот код вызывает вопросы. Что, если в момент проверки очередь была не пуста, а сразу после кто-то уже забрал задачу в другом потоке? После открывающей фигурной скобки мы не можем полагаться на истинность условия
ты прав, теперь я засунул вытаскивание в тот же захват
Кстати ответ есть простой. Вытаскиваю из очереди я только в одном месте и отвечаю за это самостоятельно
Я бы не стал так использовать лямбду, предпочёл бы вынести логику в функцию с говорящим названием. Но если хочется однострочник — как я показал выше, в C++17 можно обойтись более компактной конструкцией: while (std::lock_guard(jobs_mtx_), !jobs_.empty()) { ... } Её понятность оставляет желать лучшего, но я всё ещё нахожу эту конструкцию читаемее вызова лямбды
Ничего , что у тебя лямбда будет в каждой итерации цикла новая создаваться?
Обсуждают сегодня