In computer programming, a mutex (mutual exclusion object) is a program object that is created
so that multiple program thread
can take turns sharing the same resource, such as access to a file. Typically, when a program is
started, it creates a mutex for a given resource at the beginning by requesting it from the system
and the system returns a unique name or ID for it. After that, any thread needing the resource must
use the mutex to lock the resource from other threads while it is using the resource.
If the mutex
is already locked, a thread needing the resource is typically queued by the system and then given
control when the mutex is locked during the new
thread's use of the resource). becomes unlocked (when once more, the the mutex is locked during the new
thread's use of the resource).
Semaphore owns the resource ownership whereas mutex doesn't. Means when
the semaphore enters the critical section by setting the sem_flag as one
but because of some means(lets say dead lock) it gets blocked inside
the critical section waiting for another resource,which is being used by
another process/thread.So now no other process can enter the critical
section ...almost deadlock..means no other process can unset the
sem_flag to zero..=> implies the process which sets the lock/flag has
to unlock the flag.No other process/thread has the permission to
unlock..
On the other hand, mutex doesn't own the
ownership means even if it gets blocked inside the crtitical region,any
other process can enter the critical section.
A semaphore post (or basically unlock) can be performed by a different
thread. However, in the case of mutex, it should be unlocked only by
the same thread.
Lets understand how does the Mutual Exclusion works using this animation -
Lets understand how does the Mutual Exclusion works using this animation -
No comments:
Post a Comment