为某些代码关闭声纳

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

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

295612 次浏览

这是一个常见问题解答。你可以把//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")

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

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

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

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

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

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

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

我之所以推荐抑制特定警告的原因是,它是一个更好的实践来阻止一个特定的问题,而不是使用//NOSONAR,并冒着声纳问题在你的代码中意外爬行的风险。

你可以在常见问题解答中阅读更多有关此的内容

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

如果你想知道如何找到鱿鱼号。只需单击Sonar消息(例如Remove this method to simply inherit it.), Sonar问题将扩展。

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

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

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

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

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

实际上,很难理解哪个是问题的ID,所以我使用了@SuppressWarnings("all")注释,它基本上适用于所有规则,但更准确地说,最好使用ID。点击查看图片-> 声纳问题ID < / p >

所以当点击“Why is this an issue?”在红框中,你会看到一个有解释的屏幕。在屏幕左侧的顶部,您可以看到规则名称,左侧是该规则的id。 因此,要应用此规则,您只需将此注释添加到您的类或方法中

@SuppressWarnings(“公共java: DuplicatedBlocks")