views:

6453

answers:

4

The Java Tutorials say: "it is not possible for two invocations of synchronized methods on the same object to interleave."

What does this mean for a static method? Since a static method has no associated object, will the synchronized keyword lock on the class, instead of the object?

+10  A: 

will the synchronized keyword lock on the class, instead of the object?

Yes. :)

OscarRyz
Hey thanks again. I owe you two now.
jbu
Please answer Elaborate so that everyone can understand.
Madhu
+17  A: 

Just to add a little detail to Oscar's (pleasingly succinct!) answer, the relevant section on the Java Language Specification is 8.4.3.6, 'synchronized Methods':

A synchronized method acquires a monitor (§17.1) before it executes. For a class (static) method, the monitor associated with the Class object for the method's class is used. For an instance method, the monitor associated with this (the object for which the method was invoked) is used.

Cowan
Useful, I was looking for that quote +1
OscarRyz
+5  A: 

One point you have to be careful about (several programmers generally fall in that trap) is that there is no link between synchronized static methods and sync'ed non static methods, ie:

class A {
    static synchronized f() {...}
    synchronized g() {...}
}

Main:

A a = new A();

Thread 1:

A.f();

Thread 2:

a.g();

f() and g() are not synchronized with each other and thus can execute totally concurrently.

jfpoilpret
A: 

Unless you implement g() as follows:

g() {
    synchronized(getClass()) {
        ...
    }
}

I find this pattern useful also when I want to implement mutual exclusion between different instances of the object (which is needed when accesing an external resource, for example).

rpiaggio