谈谈Object类的终止器的实现!
在用Reflector加载mscorlib.dll后,看到System.Object类中的Finalize方法是用override修饰的.
Object是根类,显然不可能重写其他方法,这里应该是反编译工具生成的结果不正确,我们来验证这一点:
大家都知道,为了减轻开发人员的负担,C#中为Finalize方法的定义提供了特殊的语法,用这个语法来定义Finalize方法,编译器可以自动生成合适的异常处理的代码,并调用基类的Finalize方法!
Object类的Finalize方法的源代码是这样的:
~Object()
{
}
可以看到这个方法什么也没有做!
我们使用ILDasm工具来查看IL代码:
.method family hidebysig virtual instance void
Finalize() cil managed
{
.custom instance void System.Runtime.ConstrainedExecution.ReliabilityContractAttribute::.ctor(valuetype System.Runtime.ConstrainedExecution.Consistency,
valuetype System.Runtime.ConstrainedExecution.Cer) = ( 01 00 03 00 00 00 02 00 00 00 00 00 )
// 代码大小 1 (0x1)
.maxstack 8
IL_0000: ret
} // end of method Object::Finalize
这实际上是一个Virtual方法,并不是override其他方法
一般类中(如果需要的话)都是重写这个方法来添加终止器实现的。
Object是根类,显然不可能重写其他方法,这里应该是反编译工具生成的结果不正确,我们来验证这一点:
大家都知道,为了减轻开发人员的负担,C#中为Finalize方法的定义提供了特殊的语法,用这个语法来定义Finalize方法,编译器可以自动生成合适的异常处理的代码,并调用基类的Finalize方法!
Object类的Finalize方法的源代码是这样的:
~Object()
{
}
可以看到这个方法什么也没有做!
我们使用ILDasm工具来查看IL代码:
.method family hidebysig virtual instance void
Finalize() cil managed
{
.custom instance void System.Runtime.ConstrainedExecution.ReliabilityContractAttribute::.ctor(valuetype System.Runtime.ConstrainedExecution.Consistency,
valuetype System.Runtime.ConstrainedExecution.Cer) = ( 01 00 03 00 00 00 02 00 00 00 00 00 )
// 代码大小 1 (0x1)
.maxstack 8
IL_0000: ret
} // end of method Object::Finalize
这实际上是一个Virtual方法,并不是override其他方法
一般类中(如果需要的话)都是重写这个方法来添加终止器实现的。
Reflector可能没有正确的解析Object类的所以这里Reflector的反编译结果有误,并不是override其他方法。
请大家多指教!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· [AI/GPT/综述] AI Agent的设计模式综述