可以采用的方法有使用synchronized采用对操作数的加减进行加锁;
也可以采用原子类,因为原子类使用的CAS原理实现,性能比独占锁性能高。
package test;
import java.util.concurrent.atomic.AtomicInteger;
public class z {
public static void main(String[] args) {
final AtomicInteger i = new AtomicInteger(1);
Thread t1 = new Thread(new Runnable() {
public void run() {
while (true) {
int k = i.get();
if (k > 20) {
break;
}
if (k % 3 == 1) {
System.out.println("t1---->" + k);
i.getAndIncrement();
}
}
}
});
Thread t2 = new Thread(new Runnable() {
public void run() {
while (true) {
int k = i.get();
if (k > 20) {
break;
}
if (k % 3 == 2) {
System.out.println("t2---->" + k);
i.getAndIncrement();
}
}
}
});
Thread t3 = new Thread(new Runnable() {
public void run() {
while (true) {
int k = i.get();