mirror of git://gcc.gnu.org/git/gcc.git
				
				
				
			
		
			
				
	
	
		
			35 lines
		
	
	
		
			840 B
		
	
	
	
		
			Java
		
	
	
	
			
		
		
	
	
			35 lines
		
	
	
		
			840 B
		
	
	
	
		
			Java
		
	
	
	
// Test atomic increment via synchronized blocks.
 | 
						|
public class SyncTest implements Runnable {
 | 
						|
  static int counter;
 | 
						|
 | 
						|
  public void run() {
 | 
						|
    // We cache the .class value; otherwise this code is
 | 
						|
    // slow enough that it will time out in some situations.
 | 
						|
    Object lock = SyncTest.class;
 | 
						|
    for (int n = 0; n < 1000000; n++)
 | 
						|
      synchronized (lock) {
 | 
						|
        counter++;
 | 
						|
      }
 | 
						|
  }
 | 
						|
 | 
						|
  public static void main(String[] args) {
 | 
						|
    SyncTest test = new SyncTest();
 | 
						|
    Thread[] thr = new Thread[4];
 | 
						|
 | 
						|
    for (int n = 0; n < thr.length; n++) {
 | 
						|
      thr[n] = new Thread(test);
 | 
						|
      thr[n].start();
 | 
						|
    }
 | 
						|
 | 
						|
    for (int n = 0; n < thr.length; n++) {
 | 
						|
      try {
 | 
						|
        thr[n].join();
 | 
						|
      } catch (InterruptedException ex) {
 | 
						|
      }
 | 
						|
    }
 | 
						|
 | 
						|
    System.out.println(counter == 1000000 * thr.length ?
 | 
						|
      "ok" : "fail: " + counter);
 | 
						|
  }
 | 
						|
}
 |