Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

intrusive_ptr_*(): specify memory_order explicitly #10297

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

Al2Klimov
Copy link
Member

More relaxed memory_order = less safety guarantees = faster execution.

This is safe because std::shared_ptr does the same. See also: https://en.cppreference.com/w/cpp/atomic/memory_order "Typical use for relaxed memory ordering is incrementing counters, such as the reference counters of std::shared_ptr, since this only requires atomicity, but not ordering or synchronization (note that decrementing the std::shared_ptr counters requires acquire-release synchronization with the destructor)."

More relaxed memory_order = less safety guarantees = faster execution.

This is safe because std::shared_ptr does the same. See also:
https://en.cppreference.com/w/cpp/atomic/memory_order
"Typical use for relaxed memory ordering is incrementing counters, such as the reference counters of std::shared_ptr, since this only requires atomicity, but not ordering or synchronization (note that decrementing the std::shared_ptr counters requires acquire-release synchronization with the destructor)."
@Al2Klimov Al2Klimov added the core/quality Improve code, libraries, algorithms, inline docs label Jan 13, 2025
@cla-bot cla-bot bot added the cla/signed label Jan 13, 2025
@Al2Klimov Al2Klimov requested a review from oxzi January 21, 2025 09:50
@oxzi oxzi removed their request for review January 21, 2025 10:19
@oxzi
Copy link
Member

oxzi commented Jan 21, 2025

I have unassigned myself from this PR because I don't think I can give good feedback here.

However, could you please provide some deeper insights why this is a good idea? Perhaps some performance metrics? Generally speaking, "less safety guarantees" is something I would try to avoid at any cost.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
cla/signed core/quality Improve code, libraries, algorithms, inline docs
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants