|
3 / 3 / 0
Регистрация: 07.10.2018
Сообщений: 59
|
|
Атомарная запись по указателю18.04.2022, 23:00. Показов 929. Ответов 7
Метки нет (Все метки)
Здравствуйте, есть указатель на заранее выделенный массив float, нужно в нескольких потоков к этому массиву атомарно добавлять значение.
std::mutex в данном случае не очень подходит, он слишком дорогой по времени. Есть ли c/c++ возможность писать атомарно по адресу, наподобие как это делает std::atomic?
0
|
|
| 18.04.2022, 23:00 | |
|
Ответы с готовыми решениями:
7
Запись по указателю Атомарная операция Запись по ссылке или указателю в аргументы функции через макрос va_arg |
|
13 / 8 / 5
Регистрация: 14.04.2022
Сообщений: 63
|
|
| 19.04.2022, 07:37 | |
|
Что конкретно надо сделать атомарно? Надо конкретику и код.
Если записать в одно место, то std::atomic, если в два и более мест, то std::mutex.
0
|
|
|
фрилансер
6420 / 5611 / 1125
Регистрация: 11.10.2019
Сообщений: 14,923
|
||
| 19.04.2022, 10:14 | ||
|
а также использовать std::shared_mutex + shared_lock, unique_lock
0
|
||
|
13 / 8 / 5
Регистрация: 14.04.2022
Сообщений: 63
|
|
| 19.04.2022, 10:41 | |
|
std::shared_mutex еще больше тормоз чем std::mutex, там внутри счетчик читателей гоняется между потоками (ядрами) и на краткосрочных блокировках это даже хуже чем просто подождать пока другой блокировку отдаст, потом самому захватить.
0
|
|
|
фрилансер
6420 / 5611 / 1125
Регистрация: 11.10.2019
Сообщений: 14,923
|
|
| 19.04.2022, 10:50 | |
|
Dmitriy-T, чем сказки рассказывать, лучше результаты корректных измерений в студию!
0
|
|
|
13 / 8 / 5
Регистрация: 14.04.2022
Сообщений: 63
|
|||||||||||
| 19.04.2022, 12:50 | |||||||||||
|
Надо задачу конкретную. Можно сферическую придумать, тогда скажешь что подогнал решение под результат ))
Суть проблемы в следующем, допустим в основном происходит чтение, два потока читают:
Эти перекидывания между кэшами это не быстро, а их много из-за счетчика, в этом примере 3-4 получается. В случае с std::mutex счетчиков нет, гонять кэши меньше надо. Поэтому применение std::shared_mutex имеет смысл если "чтение" занимает относительно долгое время, тогда параллельный доступ читателей компенсирует потери на описанных перебросках.
0
|
|||||||||||
|
3 / 3 / 0
Регистрация: 07.10.2018
Сообщений: 59
|
||||||
| 19.04.2022, 16:54 [ТС] | ||||||
|
Задача элементарная, нужно перемножить вектор и столбец, получив матрицу. У меня массив векторов и столбцов в результате получаю массив матриц, которые мне нужно поэлементно сложить.
Вот пример функции
0
|
||||||
|
13 / 8 / 5
Регистрация: 14.04.2022
Сообщений: 63
|
||
| 19.04.2022, 17:32 | ||
т.е. тебе надо атомарно прочитать значение, прибавить к нему и записать обратно.есть std::atomic_fetch_add(), но он вроде только с atomic типами работает. Другой вариант std::atomic_compare_exchange_*(). Тут любые типы простые. Принцип такой: в цикле сначала читаем, прибавляем, и говорим сохранить результат если текущее значение такое же как изначально прочитали. Если записалось возвращает true, значит из цикла можно выходить. Попробуй, не получится - отпишись, завтра помогу.
0
|
||
| 19.04.2022, 17:32 | |
|
Помогаю со студенческими работами здесь
8
Атомарная операция Запись значения по указателю, переданному в качестве аргумента в функцию
Четыре кнопки на форме: добавить запись, удалить запись, закрыть, найти запись Switch по указателю Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
| Опции темы | |
|
|
Новые блоги и статьи
|
||||
|
И решил я переделать этот ноут в машину для распределенных вычислений
Programma_Boinc 09.11.2025
И решил я переделать этот ноут в машину для распределенных вычислений
Всем привет. А вот мой компьютер, переделанный из ноутбука.
Был у меня ноут асус 2011 года. Со временем корпус превратился. . .
|
Мысли в слух
kumehtar 07.11.2025
Заметил среди людей, что по-настоящему верная дружба бывает между теми, с кем нечего делить.
|
Новая зверюга
volvo 07.11.2025
Подарок на Хеллоуин, и теперь у нас кроме Tuxedo Cat есть еще и щенок далматинца:
Хочу еще Симбу взять, очень нравится. . .
|
Инференс ML моделей в Java: TensorFlow, DL4J и DJL
Javaican 05.11.2025
Python захватил мир машинного обучения - это факт. Но когда дело доходит до продакшена, ситуация не так однозначна. Помню проект в крупном банке три года назад: команда data science натренировала. . .
|
Mapped types (отображённые типы) в TypeScript
Reangularity 03.11.2025
Mapped types работают как конвейер - берут существующую структуру и производят новую по заданным правилам. Меняют модификаторы свойств, трансформируют значения, фильтруют ключи. Один раз описал. . .
|
|
Адаптивная случайность в Unity: динамические вероятности для улучшения игрового дизайна
GameUnited 02.11.2025
Мой знакомый геймдизайнер потерял двадцать процентов активной аудитории за неделю. А виновником оказался обычный генератор псевдослучайных чисел. Казалось бы - добавил в карточную игру случайное. . .
|
Протоколы в Python
py-thonny 31.10.2025
Традиционная утиная типизация работает просто: попробовал вызвать метод, получилось - отлично, не получилось - упал с ошибкой в рантайме. Протоколы добавляют сюда проверку на этапе статического. . .
|
C++26: Read-copy-update (RCU)
bytestream 30.10.2025
Прошло почти двадцать лет с тех пор, как производители процессоров отказались от гонки мегагерц и перешли на многоядерность. И знаете что? Мы до сих пор спотыкаемся о те же грабли. Каждый раз, когда. . .
|
Изображения webp на старых x32 ОС Windows XP и Windows 7
Argus19 30.10.2025
Изображения webp на старых x32 ОС Windows XP и Windows 7
Чтобы решить задачу, использовал интернет:
поисковики Google и Yandex, а также подсказки Deep Seek.
Как оказалось, чтобы создать. . .
|
Passkey в ASP.NET Core identity
stackOverflow 29.10.2025
Пароли мертвы. Нет, серьезно - я повторяю это уже лет пять, но теперь впервые за это время чувствую, что это не просто красивые слова. В . NET 10 команда Microsoft внедрила поддержку Passkey прямо в. . .
|