Ich habe ein seltsames Problem mit mehreren Threads und Breakpoints in IntelliJ IDEA 14.0.2. Der Code nach dem Haltepunkt wird ausgeführt, bevor er angehalten wird.Wie Debuggen einer Multi-Thread-App in IntelliJ?
import java.util.concurrent.atomic.AtomicInteger;
public class Main {
private static final int NUM_CLIENTS = 1000;
static class TestRunnable implements Runnable {
AtomicInteger lock;
@Override
public void run() {
synchronized (this.lock) {
int curCounter = this.lock.addAndGet(1);
System.out.println("Thread: " + Thread.currentThread().getName() + "; Count: " + curCounter);
if (curCounter >= NUM_CLIENTS) {
lock.notifyAll();
}
}
}
}
public static void main(final String args[]) {
final AtomicInteger lock = new AtomicInteger(0);
for (int i = 0; i < NUM_CLIENTS; i++) {
TestRunnable tr1 = new TestRunnable();
tr1.lock = lock;
new Thread(tr1).start();
}
synchronized (lock) {
try {
lock.wait();
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("Main woken up");
}
}
}
Wenn ich einen Haltepunkt in Zeile 12 (Alle Suspend), synchronized (this.lock)
führt System.out.println
noch (manchmal mehrmals). Hier ist ein Screenshot:
Soweit ich weiß, alle Threads an dem Haltepunkt stoppen sollte.
was ist Zeile 12? –
Was ist, wenn Sie den Haltepunkt an der Linie 14 setzen? (println) – Raffaele
Ich könnte Ihnen versichern, dass * einer * der Threads gestoppt hat ... welcher ist unbestimmt. – Makoto