将c#函数设置为非私有,将其标记为final或密封其声明类型
作者:互联网
我正在维护一些旧的C#代码,并且不能过多地改变它的结构.我试图以安全的方式减少一些现有的编译器警告.某些功能给了我以下警告:
Warning CS0108 ‘Function(string, string)’ hides inherited member ‘xyz.Function(string, string)’. Use the new keyword if hiding was intended.
我认为隐藏继承功能是故意的,因为该软件已经成功使用了很多年了.我认为添加“new”关键字使此函数声明为无害
private new void Function(string parm1, string parm2)
警告按预期消失了,但是这个警告出现了:
Warning CA2222 Make ‘Function(string, string)’ non-private, mark it as final, or seal its declaring type. This method was originally defined in base class ‘BaseClassName’.
除了抑制这个警告,我不确定什么是最安全的(即不改变行为)选项?我不认为我应该将这种方法设为非私人(我认为这意味着“公开”).我不确定如何使其最终或密封,以及这样做是否是正确的解决方案.
解决方法:
除非通过反射访问此方法,否则请删除“new”关键字,然后重命名它(更改任何调用站点).该方法无论如何都是私有的,因此它应该只在同一个类中使用,除非它由委托传递(然后名称无关紧要)或者如果使用反射来访问它.
在代码正确的假设下,任何调用此方法都是有意的.虽然我会检查它们并检查调用站点是否有任何错误调用错误的方法.
对方法可见性的任何改变都是有问题的,所以避免这样做※.关于制作类sealed
,它也是一个重大变化,因为可能存在从类继承的第三方代码,所以也要避免这样做.
※:可见性降低最差,因为可能存在使用该成员的第三方代码,因此这是一个重大变化.提高可见性(例如,使私有方法受保护或公开)可能会破坏类型的封装,暴露成员可能允许第三方代码混淆该类型对象的状态,因此要小心.
标签:c,compiler-warnings 来源: https://codeday.me/bug/20190711/1429515.html