Class: Thread::Mutex
| Relationships & Source Files | |
| Inherits: | Object |
| Defined in: | thread_sync.c, thread_sync.c, thread_sync.rb |
Overview
Mutex implements a simple semaphore that can be used to coordinate access to shared data from multiple concurrent threads.
Example:
semaphore = Thread::Mutex.new
a = Thread.new {
semaphore.synchronize {
# access shared resource
}
}
b = Thread.new {
semaphore.synchronize {
# access shared resource
}
}
Class Method Summary
-
.new ⇒ Mutex
constructor
Creates a new
Mutex.
Instance Attribute Summary
-
#locked? ⇒ Boolean
readonly
Returns
trueif this lock is currently held by some thread. -
#owned? ⇒ Boolean
readonly
Returns
trueif this lock is currently held by current thread.
Instance Method Summary
-
#lock ⇒ self
Attempts to grab the lock and waits if it isn’t available.
-
#sleep(timeout = nil) ⇒ Numeric?
Releases the lock and sleeps
timeoutseconds if it is given and non-nil or forever. -
#synchronize ⇒ result of the block
Obtains a lock, runs the block, and releases the lock when the block completes.
-
#try_lock ⇒ Boolean
Attempts to obtain the lock and returns immediately.
-
#lock ⇒ self
Attempts to grab the lock and waits if it isn’t available.
Constructor Details
.new ⇒ Mutex
Creates a new Mutex
# File 'thread_sync.rb', line 76
def initialize end
Instance Attribute Details
#locked? ⇒ Boolean (readonly)
Returns true if this lock is currently held by some thread.
# File 'thread_sync.rb', line 83
def locked? Primitive.cexpr! %q{ RBOOL(mutex_locked_p(mutex_ptr(self))) } end
#owned? ⇒ Boolean (readonly)
Returns true if this lock is currently held by current thread.
# File 'thread_sync.rb', line 91
def owned? Primitive.rb_mut_owned_p end
Instance Method Details
#lock ⇒ self
Attempts to grab the lock and waits if it isn’t available. Raises ::ThreadError if mutex was locked by the current thread.
# File 'thread_sync.rb', line 100
def lock Primitive.rb_mut_lock end
#sleep(timeout = nil) ⇒ Numeric?
Releases the lock and sleeps timeout seconds if it is given and non-nil or forever. Raises ::ThreadError if mutex wasn’t locked by the current thread.
When the thread is next woken up, it will attempt to reacquire the lock.
Note that this method can wakeup without explicit Thread#wakeup call. For example, receiving signal and so on.
Returns the slept time in seconds if woken up, or nil if timed out.
# File 'thread_sync.rb', line 147
def sleep(timeout = nil) Primitive.rb_mut_sleep(timeout) end
#synchronize ⇒ result of the block
Obtains a lock, runs the block, and releases the lock when the block completes. See the example under Mutex.
# File 'thread_sync.rb', line 127
def synchronize raise ThreadError, "must be called with a block" unless defined?(yield) Primitive.rb_mut_synchronize end
#try_lock ⇒ Boolean
Attempts to obtain the lock and returns immediately. Returns true if the lock was granted.
# File 'thread_sync.rb', line 109
def try_lock Primitive.rb_mut_trylock end
#lock ⇒ self
Attempts to grab the lock and waits if it isn’t available. Raises ::ThreadError if mutex was locked by the current thread.
# File 'thread_sync.rb', line 118
def unlock Primitive.rb_mut_unlock end