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 方法。

posted @ 2017-06-16 23:21  chiguozi  阅读(310)  评论(0编辑  收藏  举报