циклах от 0 до 2 Мб. С помощью с++11 как я могу реализовать такую идею: если поток по чтению обгоняет поток по записи, то поток по чтению блокируется. Если наоборот, то потоки продолжают работать без блокировок и переходят к следующим своим циклам? Т.е. поставить барьер только в том случае, когда поток по чтению обогнал потока по записи
так или иначе писатель и читатель должны быть синхронизированы. нет смысла писать, если тебя не успевают читать, не смысла писать, если не успевают писать, то что читать?
Да просто в задании пишут "обмен должен быть неблокирующий и потокобезопасным". В таком случае, что я указал выше если поставить барьер, то обмен становится блокирующим?
Попробуйте лок-фри списки, если так блокировки не устраивают.
Меня устраивает. А по заданию устраивают... Просто данные 100% сохранятся в кэш памяти и поэтому потоку по чтению будет легче читать, после того как поток по записи сохранил 2 мб памяти в кэше.
Можешь на английском написать что ты имеешь в виду?
try google "lock free list c++"
Хорошо, спасибо✊🏿 этот способ нужно применить только в крайнем случае, пишут. Если у программы есть проблемы с производительностью (программа с барьером, например).
Обсуждают сегодня