проц поддерживает, а как это в принципе происходит? Я понимаю, что можно сравнить результат с ожидаемым результатом, но чтобы это сделать, нужно же сначала прочитать текущее значение? То есть рид все равно будет блокирующим, иначе другой поток может поменять значение, пока оно читается и происходит инкремент например?
а вобще вот этот человек @jinxonik в теме этой разбирается
Идёт блокировка шины, во время которой параллельные потоки блокируются. По крайней мере, если они пытаются обратиться к тому же участку памяти. Я точно не скажу, кэш-линия вся блокируется или 8 байт или ещё сколько-то.
Ага, прочитал, спасибо. Просто в джавке есть такие классы как AtomicInteger и т.п., не очень понятно было, как они без "грязного" чтения обходятся
Одна инструкция блокирует шину, пока производит чтение, сравнение и обмен.
для xchg, лок, кажется, вообще не нужен
xchg всегда с локом работает. Поэтому не рекомендуется его использовать с памятью. Хотя, по факту, это вроде не замедляет работу, т.к. вряд ли разные потоки при нормальной работе будут обращаться через xchg к одному участку не в целях spin-lock'а. Надо б ещё потестить.
я про то что сам префикс не нужен
Да, я ж не спорю.
Обсуждают сегодня