Просто запустите код много раз, и в одно из этих счастливых времен вы сможете увидеть вмешательство потока в действии.
В этом случае очень редко наблюдать, потому что его небольшая программа и мало что происходит. Если вы делаете несколько приращений и уменьшаете потоки, то помехи по резьбе будут легче наблюдать.
class Counter {
private int c = 0;
public void increment() {c++;}
public void decrement() {c--;}
public int value() {
return c;
}
public static void main(String[] args) {
Counter x = new Counter();
Runnable r1 = new Runnable() {
@Override
public void run() {
x.increment();
}
};
Runnable r2 = new Runnable() {
@Override
public void run() {
x.decrement();
}
};
Thread t1 = new Thread(r1);
Thread t2 = new Thread(r2);
t1.start();
t2.start();
System.out.println(x.c);
}
}
Edit: Я решил добавить несколько случая нити, я не мог сопротивляться
Edit 2: Это второй edit.The множественного случая нити так, что создавало проблему выходит за рамки этого вопрос Я решил удалить его. Очевидно, я делал массив потоков и запускал их. Вместо этого будет лучше показать поток, который делает много приращений, а другой, который делает много декрементов.
Я использовал Thread.Sleep() Причинение Основной поток для сна, который будет обеспечивать печать c после того, как оба потока будут работать на нем.
class Counter {
private int c = 0;
public void increment() {
for (int i = 0; i < 10000; i++) {
c++;
}
}
public void decrement() {
for (int i = 0; i < 5000; i++) {
c--;
}
}
public int value() {
return c;
}
public static void main(String[] args) {
Counter x = new Counter();
Runnable r1 = new Runnable() {
@Override
public void run() {
x.increment();
}
};
Runnable r2 = new Runnable() {
@Override
public void run() {
x.decrement();
}
};
Thread t1 = new Thread(r1);
Thread t2 = new Thread(r2);
t1.start();
t2.start();
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
if(!(t1.isAlive() && t2.isAlive()))
System.out.println(x.c);//expected answer 5000
}
}
Примечание: Синхронные методы приращения/уменьшения дают правильный ответ. Попробуйте сами.