Аскон 2023: Проблема ABA и методы её решения в современном C++.

แชร์
ฝัง
  • เผยแพร่เมื่อ 1 ม.ค. 2025

ความคิดเห็น • 22

  • @WW-ee3zf
    @WW-ee3zf ปีที่แล้ว +14

    Modern Mr. Proper, как всегда хорош

  • @pavelrid
    @pavelrid ปีที่แล้ว +8

    Классная лекция! 👍

  • @alex_s_ciframi
    @alex_s_ciframi ปีที่แล้ว +6

    Константин, спасибо за доклад.
    Вот тут не испуганная девушка 14:07
    А вот тут испуганная 17:20
    Доклад удался :D

  • @MakinsxXx
    @MakinsxXx ปีที่แล้ว +11

    Легенда

  • @maksimusik-on
    @maksimusik-on ปีที่แล้ว

    Интересная лекция

  • @DART2WADER
    @DART2WADER ปีที่แล้ว +1

    Я надеялся что доклад выложит аскон. Но ... )))

  • @yophosphene914
    @yophosphene914 หลายเดือนก่อน

    Дайте плиз ссылку на выступление Антона Полухина про бешенный cow. Никак найти не могу

    • @tilir
      @tilir  หลายเดือนก่อน

      th-cam.com/video/rJWSSWYL83U/w-d-xo.html

    • @yophosphene914
      @yophosphene914 หลายเดือนก่อน

      @tilir спасибо большое

  • @_NightFox
    @_NightFox ปีที่แล้ว +1

    Здравствуйте, спасибо за доклад, а можно слайды?

    • @tilir
      @tilir  ปีที่แล้ว +3

      Добавил в описание под видео. Слайды тут: sourceforge.net/projects/cpp-lects-rus/files/conference-talks/

  • @rouchy_
    @rouchy_ ปีที่แล้ว +1

    Можно пожалуйста вопрос про double deletion, немного не понимаю как он возникает, если два потока сперва инициализируют Old, и второй успевает сместить head и сделать delete, то первый же поток видит в CASе что head изменился и обновляет значение Old, и затем удаляет уже его?

    • @astmix1337
      @astmix1337 ปีที่แล้ว +1

      Два потока делают head.load(), затем кто-то из них точно сделает delete, а другой может свалиться на разыменовании невалидного указателя в cas

  • @EvgeniiKim-j5r
    @EvgeniiKim-j5r ปีที่แล้ว

    Привет! У меня вопрос по поводу реализации метода push. В нем у нового узла переменная Next иницилизируется в конструкторе узла и потом не меняется. Т.е. если между созданием нового узла и попыткой его добавления (через compare_exchange_weak) кто-то окажется быстрее и обновит Head до нас, то дальше мы будем бесконечно вращаться в цикле while. Не нужно ли в случае неудачной попытки compare_exchange_weak делать New.Next = Head.load?

    • @tilir
      @tilir  ปีที่แล้ว

      Нет неправильно. Эту загрузку уже делает CAS.

    • @EvgeniiKim-j5r
      @EvgeniiKim-j5r ปีที่แล้ว

      @@tilir Понял, спасибо!

  • @alexloktionoff6833
    @alexloktionoff6833 ปีที่แล้ว

    С аппаратной поддержкой на шине, самые обычные CAS Команды начинают отлавливать запись в атомик, вероятно изменение С++ не нужно

    • @tilir
      @tilir  ปีที่แล้ว

      Сейчас когда вы пишете CAS вы говорите только о сравнении значений, транзакционность никто не обещает. С новыми примитивами вы получите гарантии на уровне абстрактной машины.

    • @alexloktionoff6833
      @alexloktionoff6833 ปีที่แล้ว

      @@tilir что-то не поняли друг друга. Может ошибаюсь, в AXI ACE спецификации для slave устройств было расширение типа дополнительного массива регистров адресов транзакций. При начале транзакции мастера слейв запоминал адрес транзакции, и слейв мониторит все записи по адресам транзакций если id мастера отличаются от инициатора то запоминает у себя флаг сломанной транзакции, мастер при завершении операций запрашивает подтверждение транзакции у слейва и слейв выдает ему бит сломанной транзакции. Таким образом отлавливая даже запись того-же самого значения в адрес транзакции /атомик/. И все сигналы инициации и проверки транзакции совпадали с обычными сигналами мастера CAS инструкции. Если мой склероз не подводит, таким образом все новые ARM процессоры с контроллером памяти поддерживающее расширение получают защиту от ABA автоматически на аппаратном уровне, изменение С++ не требуется. Лицензия AXI ACE позволяет ее свободное использование для процессоров других архитектур, таким образом и RISCV может получить решение задарма. Разве не так?

    • @tilir
      @tilir  ปีที่แล้ว +1

      Вы когда пишете программу на C++ пишете её не для конкретной архитектуры а для абстрактной машины. Поэтому просто забудьте всё что вы выше написали.

  • @ivankrutov8789
    @ivankrutov8789 ปีที่แล้ว

    А о каких футболках идет речь?

    • @tilir
      @tilir  ปีที่แล้ว +3

      На конференции выдавали Асконовские футболки с каким то кодом на них ibb.co/RSXSyMx