ABA problem (original) (raw)
In multithreaded computing, the ABA problem occurs during synchronization, when a location is read twice, has the same value for both reads, and "value is the same" is used to indicate "nothing has changed". However, another thread can execute between the two reads and change the value, do other work, then change the value back, thus fooling the first thread into thinking "nothing has changed" even though the second thread did work that violates that assumption.
Property | Value |
---|---|
dbo:abstract | In multithreaded computing, the ABA problem occurs during synchronization, when a location is read twice, has the same value for both reads, and "value is the same" is used to indicate "nothing has changed". However, another thread can execute between the two reads and change the value, do other work, then change the value back, thus fooling the first thread into thinking "nothing has changed" even though the second thread did work that violates that assumption. The ABA problem occurs when multiple threads (or processes) accessing shared data interleave. Below is a sequence of events that illustrates the ABA problem: 1. * Process reads value A from some shared memory location, 2. * is preempted, allowing process to run, 3. * writes value B to the shared memory location 4. * writes value A to the shared memory location 5. * is preempted, allowing process to run, 6. * reads value A from the shared memory location, 7. * determines that the shared memory value has not changed and continues. Although can continue executing, it is possible that the behavior will not be correct due to the "hidden" modification in shared memory. A common case of the ABA problem is encountered when implementing a lock-free data structure. If an item is removed from the list, deleted, and then a new item is allocated and added to the list, it is common for the allocated object to be at the same location as the deleted object due to MRU memory allocation. A pointer to the new item is thus often equal to a pointer to the old item, causing an ABA problem. (en) Problem ABA – rodzaj błędu w synchronizacji procesów wielowątkowych, polegający na tym, że w przypadku dwukrotnego odczytu lokacji pamięci, gdy odczytana wartość jest taka sama w obu odczytach, to „taka sama wartość” jest interpretowana jako „nic się nie zmieniło”. Jednak inny wątek mógł, między odczytami w pierwszym wątku, zmienić wartość tej lokacji, wykonać jakieś zadania, a następnie ponownie zmienić wartość lokacji do wartości równej pierwotnej, niejako oszukując pierwszy wątek, że „nic się nie zmieniło”, mimo że drugi wątek wykonał pracę, która narusza to założenie. Problem ABA pojawia się, kiedy wiele wątków (lub procesów) wykorzystuje dostęp do pamięci dzielonej naprzemiennie. Poniżej jest ciąg zdarzeń, których efektem jest problem ABA: * proces P1 czyta wartość A z pamięci dzielonej * proces P1 jest wywłaszczony, a uruchamiany jest proces P2 * proces P2 zmienia wartość w pamięci dzielonej z A na B, a następnie z powrotem na A przed wywłaszczeniem * proces P1 jest ponownie uruchamiany i widząc, że wartość w pamięci dzielonej się nie zmieniła, kontynuuje pracę Mimo że P1 może kontynuować działanie, jest także możliwe, że takie zachowanie nie będzie prawidłowe z powodu „ukrytych” zmian w pamięci dzielonej. Powszechnym przypadkiem występowania problemu ABA jest realizacja struktur danych z wykorzystaniem synchronizacji nieblokującej. Jeśli element jest usunięty z listy i zwolniony, a następnie utworzony jest nowy element, który jest do listy dodany, może się zdarzyć, że nowy obiekt zajmuje ten sam obszar pamięci co uprzednio zwolniony, na skutek optymalizacji. Wobec tego wskaźnik na nowy obiekt jest identyczny ze wskaźnikiem na stary element listy, czego wynikiem jest problem ABA. (pl) ABA問題(英: ABA problem)とは、マルチスレッドプログラミングにおいて同期化の過程で発生する問題であり、ある記憶域を二回読み出し、二回の読み出しが同じ値であることを「変更がない」とみなすことにしたとき、二回の読み出しの間に別のスレッドが値を変更し、他の作業を行った後また元の値に戻すと、最初のスレッドが誤って「変更がなかった」とみなしてしまうというものである。 ABA 問題は、複数のスレッドや(or プロセス)が共有されたメモリにアクセスする場合に生じる。下記のイベントの流れは、ABA 問題を発生させる。 * プロセス が共有メモリから値 A を読み出す * はプリエンプトされ、プロセス が実行される * は、共有メモリの値 A を値 B に書き換え、さらにプリエンプションの前に A に書き戻す * は実行を再開し、共有メモリの値が変更していないことを確認して実行を継続する は実行を継続するが、共有メモリの変更が分からなかったことにより、誤った振る舞いをする可能性がある。 ABA問題に遭遇する一般的なケースとして、ロックフリーのデータ構造を実現する場合がある。ある要素がリストから削除され、解放された後、新しい要素が割り当てられて、リストに追加されると、新規に割り当てられた要素と、削除された要素がメモリ管理上の最適化によって同じものになることがよくある。新しい要素のポインタは古いものと同一になり、ここで ABA 問題を生じる。 (ja) В многозадачных вычислениях проблема ABA возникает при синхронизации, когда ячейка памяти читается дважды, оба раза прочитано одинаковое значение, и признак «значение одинаковое» трактуется как «ничего не менялось». Однако, другой поток может выполниться между этими двумя чтениями, поменять значение, сделать что-нибудь ещё и восстановить старое значение. Таким образом, первый поток обманется, считая, что не поменялось ничего, хотя второй поток уже разрушил это предположение. Проблема ABA возникает, когда множество потоков (или процессов) обращается к разделяемой памяти поочерёдно. Вот пример последовательности событий, ведущих к проблеме ABA: * Процесс читает значение A из разделяемой памяти, * вытесняется, позволяя выполняться , * меняет значение A на B и обратно на A перед вытеснением, * возобновляет работу, видит, что значение не изменилось, и продолжает… Хотя может продолжать работу, возможно, что его поведение будет неправильным из-за других, скрытых изменений общей памяти (которые он не отслеживал). Обычно с проблемой ABA сталкиваются при реализации lock-free структур и алгоритмов. Если из списка удалить элемент, уничтожить его, а затем создать новый элемент и добавить обратно в список, есть вероятность, что новый элемент будет размещён на месте старого. Указатель на новый элемент совпадёт с указателем на старый, что и приведёт к проблеме: равенство признаков не есть равенство данных целиком. (ru) |
dbo:wikiPageExternalLink | http://www.stroustrup.com/isorc2010.pdf |
dbo:wikiPageID | 15832841 (xsd:integer) |
dbo:wikiPageLength | 9840 (xsd:nonNegativeInteger) |
dbo:wikiPageRevisionID | 1116672883 (xsd:integer) |
dbo:wikiPageWikiLink | dbr:Cache_replacement_policies dbr:PowerPC dbr:Preemption_(computing) dbr:Load-Link/Store-Conditional dbr:MIPS_architecture dbr:Computer_science dbr:Z/Architecture dbr:Garbage_collection_(computer_science) dbr:Hazard_pointer dbr:ARM_architecture dbr:DEC_Alpha dbr:Process_(computing) dbr:Read-copy-update dbr:Tagged_pointer dbc:Concurrency_(computer_science) dbr:Stack_(data_structure) dbr:RISC-V dbr:Readers–writers_problem dbr:Undefined_behavior dbr:Transactional_memory dbr:Thread_(computer_science) dbr:Compare_and_swap dbr:Lock-free |
dbp:wikiPageUsesTemplate | dbt:Cite_document dbt:Cite_web dbt:Portal dbt:Reflist dbt:Short_description dbt:Concurrent_computing |
dcterms:subject | dbc:Concurrency_(computer_science) |
rdfs:comment | In multithreaded computing, the ABA problem occurs during synchronization, when a location is read twice, has the same value for both reads, and "value is the same" is used to indicate "nothing has changed". However, another thread can execute between the two reads and change the value, do other work, then change the value back, thus fooling the first thread into thinking "nothing has changed" even though the second thread did work that violates that assumption. (en) ABA問題(英: ABA problem)とは、マルチスレッドプログラミングにおいて同期化の過程で発生する問題であり、ある記憶域を二回読み出し、二回の読み出しが同じ値であることを「変更がない」とみなすことにしたとき、二回の読み出しの間に別のスレッドが値を変更し、他の作業を行った後また元の値に戻すと、最初のスレッドが誤って「変更がなかった」とみなしてしまうというものである。 ABA 問題は、複数のスレッドや(or プロセス)が共有されたメモリにアクセスする場合に生じる。下記のイベントの流れは、ABA 問題を発生させる。 * プロセス が共有メモリから値 A を読み出す * はプリエンプトされ、プロセス が実行される * は、共有メモリの値 A を値 B に書き換え、さらにプリエンプションの前に A に書き戻す * は実行を再開し、共有メモリの値が変更していないことを確認して実行を継続する は実行を継続するが、共有メモリの変更が分からなかったことにより、誤った振る舞いをする可能性がある。 (ja) Problem ABA – rodzaj błędu w synchronizacji procesów wielowątkowych, polegający na tym, że w przypadku dwukrotnego odczytu lokacji pamięci, gdy odczytana wartość jest taka sama w obu odczytach, to „taka sama wartość” jest interpretowana jako „nic się nie zmieniło”. Jednak inny wątek mógł, między odczytami w pierwszym wątku, zmienić wartość tej lokacji, wykonać jakieś zadania, a następnie ponownie zmienić wartość lokacji do wartości równej pierwotnej, niejako oszukując pierwszy wątek, że „nic się nie zmieniło”, mimo że drugi wątek wykonał pracę, która narusza to założenie. (pl) В многозадачных вычислениях проблема ABA возникает при синхронизации, когда ячейка памяти читается дважды, оба раза прочитано одинаковое значение, и признак «значение одинаковое» трактуется как «ничего не менялось». Однако, другой поток может выполниться между этими двумя чтениями, поменять значение, сделать что-нибудь ещё и восстановить старое значение. Таким образом, первый поток обманется, считая, что не поменялось ничего, хотя второй поток уже разрушил это предположение. (ru) |
rdfs:label | ABA problem (en) ABA問題 (ja) Problem ABA (pl) Проблема ABA (ru) |
owl:sameAs | freebase:ABA problem wikidata:ABA problem dbpedia-ja:ABA problem dbpedia-pl:ABA problem dbpedia-ru:ABA problem https://global.dbpedia.org/id/2Zw8G |
prov:wasDerivedFrom | wikipedia-en:ABA_problem?oldid=1116672883&ns=0 |
foaf:isPrimaryTopicOf | wikipedia-en:ABA_problem |
is dbo:wikiPageDisambiguates of | dbr:ABA |
is dbo:wikiPageWikiLink of | dbr:Concurrent_hash_table dbr:Compare-and-swap dbr:Hazard_pointer dbr:Load-link/store-conditional dbr:ABA dbr:RISC-V dbr:Readers–writers_problem dbr:Treiber_stack |
is foaf:primaryTopic of | wikipedia-en:ABA_problem |