Class: Concurrent::AtomicReference
- Inherits:
-
AtomicReferenceImplementation
- Object
- Concurrent::AtomicReference
- Defined in:
- lib/concurrent/atomic/atomic_reference.rb
Overview
An object reference that may be updated atomically. All read and write operations have java volatile semantic.
Thread-safe Variable Classes
Each of the thread-safe variable classes is designed to solve a different problem. In general:
- Agent: Shared, mutable variable providing independent, uncoordinated, asynchronous change of individual values. Best used when the value will undergo frequent, complex updates. Suitable when the result of an update does not need to be known immediately.
- Atom: Shared, mutable variable providing independent, uncoordinated, synchronous change of individual values. Best used when the value will undergo frequent reads but only occasional, though complex, updates. Suitable when the result of an update must be known immediately.
- AtomicReference: A simple object reference that can be atomically. Updates are synchronous but fast. Best used when updates a simple set operations. Not suitable when updates are complex. AtomicBoolean and AtomicFixnum are similar but optimized for the given data type.
- Exchanger: Shared, stateless synchronization point. Used when two or more threads need to exchange data. The threads will pair then block on each other until the exchange is complete.
- MVar: Shared synchronization point. Used when one thread must give a value to another, which must take the value. The threads will block on each other until the exchange is complete.
- ThreadLocalVar: Shared, mutable, isolated variable which holds a different value for each thread which has access. Often used as an instance variable in objects which must maintain different state for different threads.
- TVar: Shared, mutable variables which provide coordinated, synchronous, change of many stated. Used when multiple value must change together, in an all-or-nothing transaction.
Instance Method Summary collapse
-
#compare_and_set(old_value, new_value) ⇒ Boolean
Atomically sets the value to the given updated value if the current value == the expected value.
-
#get ⇒ Object
Gets the current value.
-
#get_and_set(new_value) ⇒ Object
Atomically sets to the given value and returns the old value.
- #initialize(value = nil) ⇒ undocumented constructor
-
#set(new_value) ⇒ Object
Sets to the given value.
-
#to_s ⇒ String
(also: #inspect)
Short string representation.
-
#try_update {|Object| ... } ⇒ Object
Pass the current value to the given block, replacing it with the block's result.
-
#try_update! {|Object| ... } ⇒ Object
Pass the current value to the given block, replacing it with the block's result.
-
#update {|Object| ... } ⇒ Object
Pass the current value to the given block, replacing it with the block's result.
Constructor Details
#initialize(value = nil) ⇒ undocumented
195 196 197 198 199 200 201 202 203 |
# File 'lib/concurrent/atomic/atomic_reference.rb', line 195 class AtomicReference < AtomicReferenceImplementation # @return [String] Short string representation. def to_s format '%s value:%s>', super[0..-2], get end alias_method :inspect, :to_s end |
Instance Method Details
#compare_and_set(old_value, new_value) ⇒ Boolean
Atomically sets the value to the given updated value if the current value == the expected value.
that the actual value was not equal to the expected value.
195 196 197 198 199 200 201 202 203 |
# File 'lib/concurrent/atomic/atomic_reference.rb', line 195 class AtomicReference < AtomicReferenceImplementation # @return [String] Short string representation. def to_s format '%s value:%s>', super[0..-2], get end alias_method :inspect, :to_s end |
#get ⇒ Object
Gets the current value.
195 196 197 198 199 200 201 202 203 |
# File 'lib/concurrent/atomic/atomic_reference.rb', line 195 class AtomicReference < AtomicReferenceImplementation # @return [String] Short string representation. def to_s format '%s value:%s>', super[0..-2], get end alias_method :inspect, :to_s end |
#get_and_set(new_value) ⇒ Object
Atomically sets to the given value and returns the old value.
195 196 197 198 199 200 201 202 203 |
# File 'lib/concurrent/atomic/atomic_reference.rb', line 195 class AtomicReference < AtomicReferenceImplementation # @return [String] Short string representation. def to_s format '%s value:%s>', super[0..-2], get end alias_method :inspect, :to_s end |
#set(new_value) ⇒ Object
Sets to the given value.
195 196 197 198 199 200 201 202 203 |
# File 'lib/concurrent/atomic/atomic_reference.rb', line 195 class AtomicReference < AtomicReferenceImplementation # @return [String] Short string representation. def to_s format '%s value:%s>', super[0..-2], get end alias_method :inspect, :to_s end |
#to_s ⇒ String Also known as: inspect
Returns Short string representation.
198 199 200 |
# File 'lib/concurrent/atomic/atomic_reference.rb', line 198 def to_s format '%s value:%s>', super[0..-2], get end |
#try_update {|Object| ... } ⇒ Object
This method was altered to avoid raising an exception by default.
Instead, this method now returns nil
in case of failure. For more info,
please see: https://github.com/ruby-concurrency/concurrent-ruby/pull/336
Pass the current value to the given block, replacing it with the block's result. Return nil if the update fails.
195 196 197 198 199 200 201 202 203 |
# File 'lib/concurrent/atomic/atomic_reference.rb', line 195 class AtomicReference < AtomicReferenceImplementation # @return [String] Short string representation. def to_s format '%s value:%s>', super[0..-2], get end alias_method :inspect, :to_s end |
#try_update! {|Object| ... } ⇒ Object
This behavior mimics the behavior of the original
AtomicReference#try_update
API. The reason this was changed was to
avoid raising exceptions (which are inherently slow) by default. For more
info: https://github.com/ruby-concurrency/concurrent-ruby/pull/336
Pass the current value to the given block, replacing it with the block's result. Raise an exception if the update fails.
195 196 197 198 199 200 201 202 203 |
# File 'lib/concurrent/atomic/atomic_reference.rb', line 195 class AtomicReference < AtomicReferenceImplementation # @return [String] Short string representation. def to_s format '%s value:%s>', super[0..-2], get end alias_method :inspect, :to_s end |
#update {|Object| ... } ⇒ Object
Pass the current value to the given block, replacing it with the block's result. May retry if the value changes during the block's execution.
195 196 197 198 199 200 201 202 203 |
# File 'lib/concurrent/atomic/atomic_reference.rb', line 195 class AtomicReference < AtomicReferenceImplementation # @return [String] Short string representation. def to_s format '%s value:%s>', super[0..-2], get end alias_method :inspect, :to_s end |