| General topics | ||||||||||||||||
| Flow control | ||||||||||||||||
| Conditional execution statements | ||||||||||||||||
| Iteration statements (loops) | ||||||||||||||||
| Jump statements | ||||||||||||||||
| Functions | ||||||||||||||||
| Function declaration | ||||||||||||||||
| Lambda function expression | ||||||||||||||||
inline specifier | ||||||||||||||||
| Dynamic exception specifications(until C++17*) | ||||||||||||||||
noexcept specifier(C++11) | ||||||||||||||||
| Exceptions | ||||||||||||||||
| Namespaces | ||||||||||||||||
| Types | ||||||||||||||||
| Specifiers | ||||||||||||||||
| ||||||||||||||||
| Storage duration specifiers | ||||||||||||||||
| Initialization | ||||||||||||||||
| Expressions | ||||||||||||||||
| Alternative representations | ||||||||||||||||
| Literals | ||||||||||||||||
| Boolean -Integer -Floating-point | ||||||||||||||||
| Character -String -nullptr(C++11) | ||||||||||||||||
| User-defined(C++11) | ||||||||||||||||
| Utilities | ||||||||||||||||
| Attributes(C++11) | ||||||||||||||||
| Types | ||||||||||||||||
typedef declaration | ||||||||||||||||
| Type alias declaration(C++11) | ||||||||||||||||
| Casts | ||||||||||||||||
| Memory allocation | ||||||||||||||||
| Classes | ||||||||||||||||
| Class-specific function properties | ||||||||||||||||
| ||||||||||||||||
| Special member functions | ||||||||||||||||
| Templates | ||||||||||||||||
| Miscellaneous | ||||||||||||||||
| |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
(C++23) | ||||
carries_dependency (C++11)(until C++26) | ||||
(C++14) | ||||
(C++17) | ||||
(C++26) | ||||
(C++20) | ||||
(C++17) | ||||
(C++17) | ||||
(C++11) | ||||
(C++20) | ||||
(TM TS) | ||||
(C++20) |
Indicates that dependency chain in release-consumestd::memory_order propagates in and out of the function, which allows the compiler to skip unnecessary memory fence instructions.
Contents |
[[carries_dependency]] | |||||||||
This attribute may appear in two situations:
This attribute must appear on the first declaration of a function or one of its parameters in any translation unit. If it is not used on the first declaration of a function or one of its parameters in another translation unit, the program is ill-formed; no diagnostic required.
Adapted almost without change fromSO.
#include <atomic>#include <iostream> void print(int* val){std::cout<<*val<<std::endl;} void print2(int* val[[carries_dependency]]){std::cout<<*val<<std::endl;} int main(){int x{42};std::atomic<int*> p=&x;int* local= p.load(std::memory_order_consume); if(local){// The dependency is explicit, so the compiler knows that local is// dereferenced, and that it must ensure that the dependency chain// is preserved in order to avoid a fence (on some architectures).std::cout<<*local<<std::endl;} if(local){// The definition of print is opaque (assuming it is not inlined),// so the compiler must issue a fence in order to ensure that// reading *p in print returns the correct value. print(local);} if(local){// The compiler can assume that although print2 is also opaque then// the dependency from the parameter to the dereferenced value is// preserved in the instruction stream, and no fence is necessary (on// some architectures). Obviously, the definition of print2 must actually// preserve this dependency, so the attribute will also impact the// generated code for print2. print2(local);}}
Possible output:
424242
(C++11)(deprecated in C++26) | removes the specified object from thestd::memory_order_consume dependency tree (function template)[edit] |