我有以下代码:
/*01*/ final BlockingQueue<CsvFileRow> allRows = new LinkedBlockingQueue<CsvFileRow>();
/*02*/ ExecutorService exec = Executors.newFixedThreadPool(3);
/*03*/ Callable<Void> producer = new Callable<Void>() {
/*04*/ @Override
/*05*/ public Void call() throws Exception {
/*06*/ System.out.println("Before producer");
/*07*/ produceDataRows(allRows);
/*08*/ System.out.println(" After producer");
/*09*/ return null;
/*10*/ }
/*11*/ };
/*12*/ Callable<Void> consumer = new Callable<Void>() {
/*13*/ @Override
/*14*/ public Void call() throws Exception {
/*15*/ System.out.println("Before consumer");
/*16*/ consumeDataRows(allRows);
/*17*/ System.out.println(" After consumer");
/*18*/ return null;
/*19*/ }
/*20*/ };
/*21*/ exec.submit(producer);
/*22*/ exec.submit(consumer);
/*23*/ exec.shutdown();
/*24*/ exec.awaitTermination(10, TimeUnit.DAYS);
/*25*/ assert Boolean.TRUE;
我在第 7、16、21 和 25 行有断点。运行代码在断点 21,7 和 25 处停止 - 跳过断点 16!但是,代码已经执行,请看输出:
Before producer
Before consumer
After consumer
After producer
现在,如果我删除断点 7,那么调试器会在断点 21,16 和 25 处停止。
这是一个非常烦人的问题。事实上,在其他场景中,我注意到 IntelliJ 会忽略断点,这非常令人不安。
我错过了什么吗?