6

我有以下代码:

/*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 会忽略断点,这非常令人不安。

我错过了什么吗?

4

0 回答 0