当我尝试在项目的任何方法的任何执行线上选择断点时,并且我知道该方法应该被调用例如4次,Intellij会跳过此断点3次,并且仅在最后一次调用时停止。方法示例(endpoint类):
@PayloadRoot(localPart = "getRelatedCIs", namespace = "http://www.projectname.com/ws")
public GetRelatedCIsResponse getRelatedCIs(GetRelatedCIs request) throws DataAccessException, WebServiceException {
GetRelatedCIsResponse response = new GetRelatedCIsResponse();
PageData page = request.getPageData();
List<ConfigItemReference> ciRefs = translateCiRefList(request.getCiRef());
RelatedCiResult relatedCis = configItemService.getRelatedCis(ciRefs, request.getRequestedType(),
new Page(page.getPageNumber(), page.getPageSize(), page.getTotal()), request.getSort());
response.getCis().addAll(relatedCis.getCis());
page.setTotal(relatedCis.getPageInfo().getTotal());
page.setPageSize(relatedCis.getPageInfo().getPageSize());
response.setPageData(page);
System.out.println("****************************INVOCATION***************************" + request.getRequestedType());
return response;
}
断点选在方法的第一行。当程序停止时,控制台中已经打印了3行 ****************************INVOCATION***************************
在屏幕的左下方部分出现绿色通知:
在%代码引用%跳过断点,因为它发生在调试器评估内部
但是当我执行调试时,我不使用任何评估表达式功能。还有我的运行/调试配置的VM选项:
-XX:MaxPermSize=512m
-Xms256m
-Xmx1024m
-Dcom.sun.management.jmxremote=true
-Dcom.sun.management.jmxremote.port=9004
-Dcom.sun.management.jmxremote.authenticate=false
-Dcom.sun.management.jmxremote.ssl=false
IDEA-43728和断点留档中描述了该问题。
简而言之,为了避免它使用挂起线程(不是全部)断点策略。
我得到了同样的,禁用它帮助了我