Home >Java >javaTutorial >What is the difference between Lock and Synchronized in Java
Lock
and Synchronized
are both tools used in Java to solve thread safety issues
Synchronized
is the synchronization keyword in java. Lock is the interface provided in the J.U.C package. This interface has many implementation classes, including important ones like ReentrantLock. To implement locking, Synchronized can control the strength of the lock in two ways
One is to modify the synchronized
keyword at the method level, the other is to The first is to modify the code block. You can control the scope of the lock through the life cycle of the lock object. If the lock object is a static object or a class object, then the lock is a global lock. If The lock object is an ordinary instance object, so the scope of the lock depends on the life cycle of the instance. The granularity of the lock in Lock is determined by the lock() method and unlock()
method provided in it
The code between the lock() method and the unlock() method can ensure thread safety , and the scope of the lock depends on the life cycle of the Lock instance. Lock is more flexible than Synchronized
. Lock can decide independently when to lock and when to release the lock. You only need to call the lock() and unlock methods. Lock also provides A non-blocking competition lock method is called tryLock()
. This method can tell the current thread whether other threads are already using the lock by returning true/false, and Synchronized is a keyword, so it It is impossible to implement a non-blocking competitive lock method. Synchronized
The release of the lock is passive. It will be released only after the execution of the Synchronized synchronized code block is completed, or when an exception occurs in the code. Lock provides a fair lock. And the mechanism of unfair lock. Fair lock means that when threads compete for lock resources, other threads are already queuing or waiting for the lock to be released. Then the thread currently competing for the lock cannot jump into the queue. Unfair lock means that no matter whether there is When a thread is queuing for a lock, it will try to compete for a lock. Synchronized only provides an unfair lock implementation. 3. From a performance perspective,
is not much different from lock in terms of performance, but there will be some differences in implementation, Synchronized
Introducing biased locks, lightweight locks, heavyweight locks and lock upgrade mechanisms to achieve lock optimization, while Lock uses spin locks to achieve performance optimization
The above is the detailed content of What is the difference between Lock and Synchronized in Java. For more information, please follow other related articles on the PHP Chinese website!