微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

c# – 为什么调用Object类的一些函数在一个原始类型的实例上需要装箱?

我发现如果我运行以下代码行.
int i = 7;
i.GetHashCode(); //where GetHashCode() is the derived
                 //function from System.Object

没有拳击完成,但是如果我调用i.GetType()(来自System.Object的另一个派生函数)代替GetHashCode(),则需要一个拳击来调用GetType(),为什么不可能调用GetType()对原始类型的实例直接,没有拳击,而它可能调用GetHashCode()没有拳击?

解决方法

这里的关键是GetType()不是虚拟的,不能被覆盖.由于struct被有效地封装,所以方法不能比struct重写,因此运行时和编译器可以将已被重写为静态调用的struct方法.

如果你编写一个结构(很少),你应该覆盖所有的方法,如ToString(),Equals(),GetHashCode()这个原因.如果你不这样就必须盒子.但是,GetType()不能被覆盖,因此需要装箱.

这实际上导致了一些奇怪的边缘情况与Nullable 一个空的nullable< t=""> 框为null,所以: 一个空的nullable<>

int i = obj.GetHashCode(); // fine
Type t = obj.GetType(); // boom

原文地址:https://www.jb51.cc/csharp/93981.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐