import java.util.concurrent.locks.Lock; import java.util.concurrent.locks.ReentrantLock; public class SharedData { private int count; private Lock lock; public SharedData() { count = 0; } public void increment() { try { } finally { } } public int getCount() { return count; } public static void main(String[] args) { SharedData sharedData = new SharedData(); Thread t1 = new Thread(() -> { for (int i = 0; i < 1000; i++) { sharedData.increment(); } }); Thread t2 = new Thread(() -> { for (int i = 0; i < 1000; i++) { sharedData.increment(); } }); t1.start(); t2.start(); try { t1.join(); t2.join(); } catch (InterruptedException e) { e.printStackTrace(); } System.out.println("Count: " + sharedData.getCount()); } } <dependency> <groupId>org.jcommon.concurrent</groupId> <artifactId>jcommon-concurrency</artifactId> <version>1.0.0</version> </dependency>


上一篇:
下一篇:
切换中文