std::atomic_ref<T>:: operator+=,-=
      From cppreference.com
     
     
     
     
      
       <
       
        cpp
       
        |
       
        atomic
       
        |
       
        atomic ref
       
      
     
     
     
     
        
         C++
        
        
         
          
           
          
          
         
        
       
       
        
         Concurrency support library
        
        
         
          
           
            
          
          
          
         
        
       
       | 
 | 
 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
        
         
          std::atomic_ref
         
        
        
         
          
           
            
          
          
          
         
        
       
       | Member functions | ||||
| 
                
                 
                  
                   (C++26)
                  
                 
                
                | ||||
| Constants | ||||
| Specialized member functions | ||||
| Specialized for integral, floating-point and pointer types | ||||
| 
                
                 
                  
                   atomic_ref::operator+=
                  
                  
                   atomic_ref::operator-=
                  
                 
                
                | ||||
| Specialized for integral and pointer types only | ||||
| 
                
                 
                  
                   (C++26)
                  
                 
                
                | ||||
| 
                
                 
                  
                   (C++26)
                  
                 
                
                | ||||
| Specialized for integral types only | ||||
| 
           member only of
            
            atomic_ref<
            
             Integral
            
            >
           and
            atomic_ref<
            
             Floating
            
            >
           specializations | ||
| 
           
            T operator
            
             +
            
            
             =
            
            
             (
            
            T arg
            
             )
            
            
             const
            
            
             noexcept
            
            
             ;
            
           
           | (1) | (since C++20) | 
| 
           
            T operator
            
             -
            
            
             =
            
            
             (
            
            T arg
            
             )
            
            
             const
            
            
             noexcept
            
            
             ;
            
           
           | (2) | (since C++20) | 
| 
           member only of
            
            atomic_ref<T*>
           partial specialization | ||
| 
           
            T
            
             *
            
            operator
            
             +
            
            
             =
            
            
             (
            
            
             
              std::
              
               ptrdiff_t
              
             
            
            arg
            
             )
            
            
             const
            
            
             noexcept
            
            
             ;
            
           
           | (3) | (since C++20) | 
| 
           
            T
            
             *
            
            operator
            
             -
            
            
             =
            
            
             (
            
            
             
              std::
              
               ptrdiff_t
              
             
            
            arg
            
             )
            
            
             const
            
            
             noexcept
            
            
             ;
            
           
           | (4) | (since C++20) | 
Atomically replaces the current value of the referenced object with the result of computation involving the previous value and arg . These operations are read-modify-write operations.
- operator + = performs atomic addition. Equivalent to return fetch_add ( arg ) + arg ; .
- operator - = performs atomic subtraction. Equivalent to return fetch_sub ( arg ) - arg ; .
       
        1,2)
       
       For signed integral types, arithmetic is defined to use two’s complement representation. There are no undefined results.
      
      
       
       
       For floating-point types, the
       
        floating-point environment
       
       in effect may be different from the calling thread's floating-point environment. The operation need not be conform to the corresponding
       
        
         std::numeric_limits
        
       
       traits but is encouraged to do so. If the result is not a representable value for its type, the result is unspecified but the operation otherwise has no undefined behavior.
      
      
       
        3,4)
       
       The result may be an undefined address, but the operations otherwise have no undefined behavior. The program is ill-formed if
       
      
        T
       
       is not an object type.
      Parameters
| arg | - | the argument for the arithmetic operation | 
Return value
The resulting value (that is, the result of applying the corresponding binary operator to the value immediately preceding the effects of the corresponding member function).
Notes
       Unlike most compound assignment operators, the compound assignment operators for
       
        atomic_ref
       
       do not return a reference to their left-hand arguments. They return a copy of the stored value instead.
      
Example
| This section is incomplete Reason: no example | 
See also
| atomically adds the argument to the value stored in the referenced object and obtains the value held previously (public member function) | |
| atomically subtracts the argument from the value stored in the referenced object and obtains the value held previously (public member function) | |
| atomically increments or decrements the referenced object by one (public member function) | |
| atomically performs bitwise AND, OR, XOR with the referenced value (public member function) | 
      Retrieved from "
      
       https://en.cppreference.com/mwiki/index.php?title=cpp/atomic/atomic_ref/operator_arith2&oldid=171463
      
      "