▲ | adrian_b 5 days ago | |||||||||||||||||||||||||
This matters only for shared data structures. It is irrelevant for thread-local data. For shared data structures, you have more to worry about, so regardless if you use indices or pointers you must use either atomic operations or means to ensure exclusive access to the entire data structure or means to detect the need for retries when using optimistic accesses. | ||||||||||||||||||||||||||
▲ | kazinator 5 days ago | parent [-] | |||||||||||||||||||||||||
Well, solving/mitigating the ABA ambiguity can debug use-after-free errors in single-threaded programs also. Because when a pointer A is freed to B, and then recycled again for a new object, we can make it into a different pointer A' (e.g. with a tagging scheme). So then when the old A pointer copies are lingering around, we can tell they are invalid due to having the wrong tag. Solving ABA is probably a point in favor of indices (if we are working in a higher level language) because their type supports the bit operations for tagging. However, some hardware has support for hardware tagging for pointers. E.g. ARM; Android uses it. | ||||||||||||||||||||||||||
|