我的代码中有几个实例,其中Style cop给出了:
“SA1119:该行包含不必要的括号。”
如果我有一行代码说明:
,我完全赞同这一点int someValue = (((12 + 3) + 5));
然而,当我有更复杂的东西时:
textXpos = ((((float)this.Width - imageoffset) - textsize.Width) / 2);
据我所知,我可以改写:
textXpos = (((float)this.Width - imageoffset - textsize.Width) / 2);
它将评估相同的值,但我发现第一个更容易阅读。有没有办法告诉styecop忽略这个错误的实例?
或者我是否需要通过将一些方程分配给临时变量来解决这个问题?
我不想将此代码包装在自动生成的区域中,因为我希望样式警察来评估此部分代码。
由于
根据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;
}
但这似乎没有任何影响?我错过了什么吗?
答案 0 :(得分:4)
您可以在方法标题之前添加以下语句:
[SuppressMessage("Microsoft.StyleCop.CSharp.MaintainabilityRules", "SA1119:StatementMustNotUseUnnecessaryParenthesis", Justification = "Better for readability.")]
但是整个方法将忽略警告SA1119。
编辑:至少删除第一个和最后一个括号:
textXpos = (((float)this.Width - imageoffset) - textsize.Width) / 2;