4.1 所有类型都从 System.Object 派生

  • "运行时"要求各个类型最终都从 System.Object 派生。(显示继承/隐式继承)

  • 提供公共方法(public):
    • Equals 判断两个对象相等,true 表示相等。
    • GetHashCode 返回对象的哈希值。
    • ToString 默认返回类型的完整名称(this.GetType().FullName
    • GetType 返回 Type 派生的一个类型实例,指出对象的类型,返回的 Type 对象可以与反射类配合,获取与对象类型相关的元数据信息。GetType 为非虚方法,防止子类重写,隐瞒其类型,破坏安全性。
  • 提供受保护方法(protected):
    • MemberwiseClone MemberwiseClone方法创建的新对象,然后将当前对象的非静态字段复制到新的对象创建的浅表副本。 如果字段是值类型,则执行字段的按位复制。 如果字段是引用类型,引用将复制。(MSDN)
    • Finalize 垃圾回收判断应被回收之后,对象内存被实际回收之前,会调用该虚方法。
  • new 操作符创建对象时所作的操作:
    1. 计算类型及其所有基类型(直到 System.Object,尽管它没有定义自己的实例字段)中定义的所有实例字段需要的字节数。每个对象在堆上都需要一些额外成员—— type object pointer(类型对象指针)和 sync block index (同步块索引)——来管理对象。这些额外成员的字节要计入对象大小。
    2. 从托管堆中分配类型需要的字节数,从而为对象分配内存,所有的字节都设置为0。
    3. 初始化对象的 type object pointer 和 sync block index 成员。
    4. 调用实例的构造方法,并传递 new 调用中指定的实参。大多数编译器都在构造函数中自动生成代码来调用积累的构造函数。每个类型的构造函数第一反应则初始化该类型定义的实例字段。
  • 没有 delete 操作符,没有办法显示的释放对象分配的内存。CLR 通过垃圾回收机制来自动释放内存。


  • Object 还提供两个静态方法:

    • Equal(Object, Object) 判断两个对象相等。

      静态 Equals(Object, Object) 方法指示两个对象,objA 和 objB,是否相等。 它还使您能够值是相等的 null 的测试对象。 它将 objA 和objB 相等的如下:

      • 它确定两个对象是否表示同一对象引用。 如果参数,则方法返回 true。 此测试具有名为 ReferenceEquals 方法等效。 此外,在中,如果 objA 和 objB 是 null,该方法返回 true。
      • 它确定 objA 或 objB 是否 null。 如果是这样,则返回 false。
      • 如果两个对象不表示同一对象引用,且均不为 null,它调用 objA。Equals(objB)和返回结果。 这意味着,如果 objA 重写 Equals(Object) 方法,该重写调用。
    • ReferenceEquals 确定指定的 Object 实例是否是相同的实例。

      不像 Equals 方法和相等运算符,ReferenceEquals 方法不能被重写。 为此,如果要测试两个对象引用的平等,且不确定 Equals 方法的实现时,可以调用 ReferenceEquals 方法。 但是,请注意,如果 objA 和 objB 是值类型,则它们先装箱,然后传递给 ReferenceEquals 方法。

时间: 2024-08-07 13:06:22

4.1 所有类型都从 System.Object 派生的相关文章

第4章 类型基础 -- 4.1 所有类型都从System.Object派生

4.1 所有类型都从System.Object派生 “运行时”要求每个类型最终都从System.Object类型派生. 由于所有类型最终都从System.Object派生,所以每个类型的每个对象都保证了一组最基本的方法. System.Object类提供了如下表所示的公共实例方法: 表4-1 System.Object的公共方法 Equals 若两个对象具有相同的值,就返回 true .详情请参考"对象相等性和同一性" GetHashCode 返回对象的值的哈希码.如果某个类型的对象要

是否存在不继承自System.Object类型的类

分析问题 可能读者的固有思维认为.NET中所有的类型都必须继承自System.Object,这样的认识过于绝对,且不完全正确.在.NET中,.NET设计小组为中间语言的编译器ILasm.exe添加了noautoinherit开关,当这个开关被打开时,编译器将不会默认年地把类型认为继承自System.Object. 首先介绍一下中间语言的编译工具:ILasm.exe.这是.NET Framework提供的一个编译工具,它的作用是把中间语言(MSIL)编译成可执行的PE文件.该工具非常有用,它不仅使

c# System.Object类和数据的安全转型

.NET Fraework 最重要的引用类型之一是System命名空间中Object类.所有的类都是System.Object的派生类.System.Object类型的变量System.Object的别名.可以写成Object.优先考虑Object Object类型的变量能够引用任何引用类型的任何对象.除此之外Object类型的变量也能引用值类型的实例. 在强制类型转换的过程中,如果内存中的对象类型与指定的类型不匹配,运行时会抛出InavalidCastException异常,在编写程序的时候,

无法将类型“System.Nullable`1”强制转换为类型“System.Object”。LINQ to Entities 仅支持强制转换 EDM 基元或枚举类型。

在一个项目中使用LINQ和EF时出现了题目所示的异常,搜索了很多资料都找不到解决办法,主要是因为EF方面的知识欠缺. 先将情况记录如下,以供以后参考. 查询主要设计两张表,由外键关联: 在进行下面的查询时,出现异常:无法将类型“System.Nullable`1”强制转换为类型“System.Object”.LINQ to Entities 仅支持强制转换 EDM 基元或枚举类型. public ActionResult GetIpSegments() { //List<Ipsegment>

Entity FreamWork 无法创建“System.Object”类型的常量值。此上下文仅支持基元类型或枚举类型错误解决

Entity FreamWork 无法创建“System.Object”类型的常量值.此上下文仅支持基元类型或枚举类型错误解决: 最近在开发中把我原来抄的架构里面的主键由固定的Guid改成了可以泛型指定的类型,结果,发现执行EF在查询的时候,不能支持equal,只能用==,理由很简单,因为equal是object的方法,虽然所有的类都是object的子类,但是ef不支持复杂类型的直接检索,只能用简单类型,比如常用的string,int,guid,这些,都可以做==,也可以用来检索.但是比如Per

类型与通用语言运行时:System.Object

CLR 要求每个类型最终都要继承自 System.Object 类型 1 //隐式继承 Object 2 class Employee { 3 ... 4 } 5 6 //显示继承继承 Object 7 class Employee : System.Object { 8 ... 9 } 类型定义(C#)描述 System.object 的公有方法 Equals:如果两个对象具有相同的值,方法返回 true GetHashCode:方法返回对象的值的散列码.如果一个对象被用作散列表的一个键值,那

.NET基础 (11)类型的基类System.Object

类型的基类System.Object1 是否存在不继承自System.Object类型的类2 在System.Object中定义的三个比较方法有何异同3 如何重写GetHashCode方法 类型的基类System.Object1 是否存在不继承自System.Object类型的类 通过运行ILasm.exe的noautoinherit开关,可以生产不从System.Object继承的类型,这种类型是不安全的类型,也不建议使用. 2 在System.Object中定义的三个比较方法有何异同 静态方

无法创建“System.Object”类型的常量值。此上下文仅支持基元类型或枚举类型

Entity FreamWork 无法创建“System.Object”类型的常量值.此上下文仅支持基元类型或枚举类型错误解决: 最近在开发中把我原来抄的架构里面的主键由固定的Guid改成了可以泛型指定的类型,结果,发现执行EF在查询的时候,不能支持equal,只能用==,理由很简单,因为equal是object的方法,虽然所有的类都是object的子类,但是ef不支持复杂类型的直接检索,只能用简单类型,比如常用的string,int,guid,这些,都可以做==,也可以用来检索.但是比如Per

预定义的类型“System.Object”未定义或未导入

生成网站或项目时,VS 2010 出现如下错误: 预定义的类型“System.Object”未定义或未导入 无效的引用选项 无法引用目录 解决方法: 关掉 VS 2010 重新打开即可.