X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=tests%2Forg.simantics.db.tests%2Fsrc%2Forg%2Fsimantics%2Fdb%2Ftests%2Fperformance%2Fjava%2FSynchronizedAccessTest.java;fp=tests%2Forg.simantics.db.tests%2Fsrc%2Forg%2Fsimantics%2Fdb%2Ftests%2Fperformance%2Fjava%2FSynchronizedAccessTest.java;h=f1ab3e1bd421f3ce75464b1ebaed99026569b4ca;hb=67fd62f9c742337ec80eef658192db198a0efaac;hp=0000000000000000000000000000000000000000;hpb=cde82ba81327d5515fdca362f7f4c70f5103ae80;p=simantics%2Fplatform.git diff --git a/tests/org.simantics.db.tests/src/org/simantics/db/tests/performance/java/SynchronizedAccessTest.java b/tests/org.simantics.db.tests/src/org/simantics/db/tests/performance/java/SynchronizedAccessTest.java new file mode 100644 index 000000000..f1ab3e1bd --- /dev/null +++ b/tests/org.simantics.db.tests/src/org/simantics/db/tests/performance/java/SynchronizedAccessTest.java @@ -0,0 +1,191 @@ +/******************************************************************************* + * Copyright (c) 2007, 2010 Association for Decentralized Information Management + * in Industry THTH ry. + * All rights reserved. This program and the accompanying materials + * are made available under the terms of the Eclipse Public License v1.0 + * which accompanies this distribution, and is available at + * http://www.eclipse.org/legal/epl-v10.html + * + * Contributors: + * VTT Technical Research Centre of Finland - initial API and implementation + *******************************************************************************/ +package org.simantics.db.tests.performance.java; + +import gnu.trove.map.hash.TIntIntHashMap; + +import java.util.concurrent.CountDownLatch; +import java.util.concurrent.Semaphore; +import java.util.concurrent.locks.Lock; +import java.util.concurrent.locks.ReentrantLock; + +import org.simantics.db.testing.base.TestCommonPerf; + + +public class SynchronizedAccessTest extends TestCommonPerf { + + public void perform3(int threads) throws InterruptedException { + + final Lock lock = new ReentrantLock(false); + final TIntIntHashMap map = new TIntIntHashMap(); + + class CounterThread extends Thread { + + final private int index; + final private Semaphore start; + final private CountDownLatch latch; + + public CounterThread(int index, Semaphore start, CountDownLatch latch) { + this.index = index; + this.start = start; + this.latch = latch; + } + + @Override + public void run() { + + try { + start.acquire(); + } catch (InterruptedException e) { + e.printStackTrace(); + } + + for(int i=0;i<1000000;i++) { + lock.lock(); + map.put(i, i); + lock.unlock(); + } + + latch.countDown(); + + } + + } + + CountDownLatch latch = new CountDownLatch(threads); + Semaphore starter = new Semaphore(0); + + for(int i=0;i