是否可以关闭特定代码块的声纳(www.sonarsource.org)测量,哪些代码块不想被测量?

Findbugs输出的“保存堆栈跟踪”警告就是一个例子。当离开服务器时,如果客户端不知道异常(例如,因为客户端没有包含异常的JAR),我很可能只想将消息传递回客户端,而不包括我刚刚捕获的实际异常。


当前回答

我在声纳5.6中找不到鱿鱼的数量,用这个注释也可以:

@SuppressWarnings({"pmd:AvoidCatchingGenericException", "checkstyle:com.puppycrawl.tools.checkstyle.checks.coding.IllegalCatchCheck"})

其他回答

这是一个常见问题。你可以把//NOSONAR放在行末触发警告。

/ / NOSONAR 对于大多数语言,SonarQube支持在问题行末尾使用通用机制://NOSONAR。这将抑制所有的问题——现在和将来——可能会在线上提出。

不过,我更喜欢使用FindBugs机制,它包括添加@SuppressFBWarnings注释:

@edu.umd.cs.findbugs.annotations.SuppressFBWarnings(
    value = "NAME_OF_THE_FINDBUGS_RULE_TO_IGNORE",
    justification = "Why you choose to ignore it")

我在声纳5.6中找不到鱿鱼的数量,用这个注释也可以:

@SuppressWarnings({"pmd:AvoidCatchingGenericException", "checkstyle:com.puppycrawl.tools.checkstyle.checks.coding.IllegalCatchCheck"})

使用//NOSONAR在行中,如果它是你无法帮助你的代码的东西,你会得到警告。它的工作原理!

我建议你尝试使用@SuppressWarnings("squid:S2078")来抑制特定的警告。

为了抑制多个警告,你可以这样做@SuppressWarnings({"squid:S2078", "squid:S2076"})

还有//NOSONAR注释告诉SonarQube忽略某一行的所有错误。

最后,如果您拥有用户界面的适当权限,您可以直接从界面发出假阳性标志。

我建议屏蔽特定警告的原因是,屏蔽特定问题比使用//NOSONAR和冒着Sonar问题意外潜入代码的风险是一个更好的实践。

你可以在FAQ中阅读更多相关内容

编辑:6/30/16 SonarQube现在被称为SonarLint

如果你想知道如何找到鱿鱼号。只需单击Sonar消息(例如,删除此方法以简单地继承它),Sonar问题将扩展。

在左下方,它将有鱿鱼的编号(例如鱿鱼:S1185维护性>理解性)

所以你可以通过@SuppressWarnings("squid:S1185")来抑制它

可以使用SuppressWarnings对类或方法进行注释

@java.lang.SuppressWarnings("squid:S00112")

squid:S00112在这种情况下是声纳问题ID。你可以在Sonar UI中找到这个ID。转到问题下钻。找到您想要压制警告的问题。在代码中的红色问题框中有一个规则链接,其中包含给定问题的定义。单击后,您将在页面顶部看到ID。