 
                            
********** Text below this note not yet converted from Java to C! ************
...
This noncompliant code example attempts to guard access to the static counter field using a non-static lock object. When two Runnable tasks are started, they create two instances of the lock object and lock on each instance separately.
...
| publicfinalclassCountBoxes implementsRunnable {  privatestaticvolatileintcounter;  // ...  privatefinalObject lock = newObject(); | 
|   @Overridepublicvoidrun() {    synchronized(lock) {      counter++;      // ...    }  } | 
|   publicstaticvoidmain(String[] args) {    for(inti = 0; i < 2; i++) {    newThread(newCountBoxes()).start();    }  }} | 
This example fails to prevent either thread from observing an inconsistent value of counter because the increment operation on volatile fields fails to be atomic in the absence of proper synchronization. (See rule VNA02-J. Ensure that compound operations on shared variables are atomic for more information.)
...
This noncompliant code example uses method synchronization to protect access to a static class counter field.
| publicfinalclassCountBoxes implementsRunnable {  privatestaticvolatileintcounter;  // ... | 
|   publicsynchronizedvoidrun() {    counter++;    // ...  }  // ...} | 
In this case, the method synchronization uses the intrinsic lock associated with each instance of the class rather than the intrinsic lock associated with the class itself. Consequently, threads constructed using different Runnable instances may observe inconsistent values of counter.
...
This compliant solution ensures the atomicity of the increment operation by locking on a static object.
...
| publicclassCountBoxes implementsRunnable {  privatestaticintcounter;  // ...  privatestaticfinalObject lock = newObject(); | 
|   publicvoidrun() {    synchronized(lock) {      counter++;      // ...    }  }  // ...} | 
It is unnecessary to declare the counter variable volatile when using synchronization.
...
Using an instance lock to protect static shared data can result in nondeterministic behavior.
| Rule | Severity | Likelihood | Detectable | 
|---|
| Repairable | Priority | Level | 
|---|---|---|
| CON06-C | Medium | Probable | 
| No | No | 
| P4 | 
| L3 | 
Automated Detection
Some static analysis tools can detect violations of this rule.
Related Guidelines
| Tool | Version | Checker | Description | ||||||
|---|---|---|---|---|---|---|---|---|---|
| Astrée | 
 | Supported, but no explicit checker | 
Related Guidelines
Key here (explains table format and definitions)
| Taxonomy | Taxonomy item | Relationship | 
|---|---|---|
| CWE 2.11 | 
| CWE-667, Improper Locking | Prior to 2018-01-12: CERT: | 
Bibliography
| [API 2006] | 
...
...