我的代码中有几个例子,样式警察给出的例子是:
"SA1119:行包含不必要的括号。“
现在我完全同意这一点,如果我有一行代码:
int someValue = (((12 + 3) + 5));然而,当我有更复杂的事情时,比如:
textXpos = ((((float)this.Width - imageoffset) - textsize.Width) / 2);我知道我可以改写如下:
textXpos = (((float)this.Width - imageoffset - textsize.Width) / 2);它将计算出相同的值,但我发现第一个更容易读懂。是否有一种方法可以告诉styecop忽略此错误实例?
或者我需要通过给临时变量分配一些等式来解决这个问题吗?
我不想将此代码包装在自动生成的区域中,因为我希望样式cop对这一部分代码进行评估。
谢谢
根据ken2k的建议,我尝试了以下几点:
using System.Diagnostics.CodeAnalysis;。。。
[SuppressMessage("StyleCop.CSharp.MaintainabilityRules", "SA1119:StatementMustNotUseUnnecessaryParenthesis", Justification = "Better for readability.")]
public int Testmethod()
{
int returnValue = (((5 - 5) - 5) / 2);
return returnValue;
}但这似乎没有任何效果?我是不是遗漏了什么?
发布于 2012-01-09 14:20:16
可以在方法的标题之前添加以下语句:
[SuppressMessage("Microsoft.StyleCop.CSharp.MaintainabilityRules", "SA1119:StatementMustNotUseUnnecessaryParenthesis", Justification = "Better for readability.")]但是对于整个方法,警告SA1119将被忽略。
编辑:至少删除第一个和最后一个括号:
textXpos = (((float)this.Width - imageoffset) - textsize.Width) / 2;https://stackoverflow.com/questions/8789799
复制相似问题