Object.cs source code in C# .NET

Source code for the .NET framework in C#

                        

Code:

/ 4.0 / 4.0 / untmp / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / clr / src / BCL / System / Object.cs / 1305376 / Object.cs

                            // ==++== 
//
//   Copyright (c) Microsoft Corporation.  All rights reserved.
//
// ==--== 
/*============================================================
** 
** Class:  Object 
**
** 
** Object is the root class for all CLR objects.  This class
** defines only the basics.
**
** 
===========================================================*/
 
namespace System { 
    using System;
    using System.Runtime; 
    using System.Runtime.InteropServices;
    using System.Runtime.CompilerServices;
    using System.Runtime.ConstrainedExecution;
    using System.Runtime.Versioning; 
    using System.Diagnostics.Contracts;
    using CultureInfo = System.Globalization.CultureInfo; 
    using FieldInfo = System.Reflection.FieldInfo; 
    using BindingFlags = System.Reflection.BindingFlags;
#if FEATURE_REMOTING 
    using RemotingException = System.Runtime.Remoting.RemotingException;
#endif
// The Object is the root class for all object in the CLR System. Object
// is the super class for all other CLR objects and provide a set of methods and low level 
// services to subclasses.  These services include object synchronization and support for clone
// operations. 
// 
 //This class contains no data and does not need to be serializable
[Serializable] 
[ClassInterface(ClassInterfaceType.AutoDual)]
[System.Runtime.InteropServices.ComVisible(true)]
public class Object
{ 
    // Creates a new instance of an Object.
    [ReliabilityContract(Consistency.WillNotCorruptState, Cer.MayFail)] 
    public Object() 
    {
    } 

    // Returns a String which represents the object instance.  The default
    // for an object is to return the fully qualified name of the class.
    // 
    public virtual String ToString()
    { 
        return GetType().ToString(); 
    }
 
    // Returns a boolean indicating if the passed in object obj is
    // Equal to this.  Equality is defined as object equality for reference
    // types and bitwise equality for value types using a loader trick to
    // replace Equals with EqualsValue for value types). 
    //
 
#if !FEATURE_CORECLR 
    [TargetedPatchingOptOut("Performance critical to inline across NGen image boundaries")]
#endif 
    public virtual bool Equals(Object obj)
    {
        return RuntimeHelpers.Equals(this, obj);
    } 

#if !FEATURE_CORECLR 
    [TargetedPatchingOptOut("Performance critical to inline across NGen image boundaries")] 
#endif
    public static bool Equals(Object objA, Object objB) 
    {
        if (objA==objB) {
            return true;
        } 
        if (objA==null || objB==null) {
            return false; 
        } 
        return objA.Equals(objB);
    } 

    [ReliabilityContract(Consistency.WillNotCorruptState, Cer.Success)]
#if !FEATURE_CORECLR
    [TargetedPatchingOptOut("Performance critical to inline across NGen image boundaries")] 
#endif
    public static bool ReferenceEquals (Object objA, Object objB) { 
        return objA == objB; 
    }
 
    // GetHashCode is intended to serve as a hash function for this object.
    // Based on the contents of the object, the hash function will return a suitable
    // value with a relatively random distribution over the various inputs.
    // 
    // The default implementation returns the [....] block index for this instance.
    // Calling it on the same object multiple times will return the same value, so 
    // it will technically meet the needs of a hash function, but it's less than ideal. 
    // Objects (& especially value classes) should override this method.
    // 
#if !FEATURE_CORECLR
    [TargetedPatchingOptOut("Performance critical to inline across NGen image boundaries")]
#endif
    public virtual int GetHashCode() 
    {
        return RuntimeHelpers.GetHashCode(this); 
    } 

    // Returns a Type object which represent this object instance. 
    //
    [System.Security.SecuritySafeCritical]  // auto-generated
    [Pure]
    [ResourceExposure(ResourceScope.None)] 
    [MethodImplAttribute(MethodImplOptions.InternalCall)]
    public extern Type GetType(); 
 
    // Allow an object to free resources before the object is reclaimed by the GC.
    // 
    [ReliabilityContract(Consistency.WillNotCorruptState, Cer.Success)]
    ~Object()
    {
    } 

    // Returns a new object instance that is a memberwise copy of this 
    // object.  This is always a shallow copy of the instance. The method is protected 
    // so that other object may only call this method on themselves.  It is entended to
    // support the ICloneable interface. 
    //
    [System.Security.SecuritySafeCritical]  // auto-generated
    [ResourceExposure(ResourceScope.None)]
    [MethodImplAttribute(MethodImplOptions.InternalCall)] 
    protected extern Object MemberwiseClone();
 
 
    // Sets the value specified in the variant on the field
    // 
    [System.Security.SecurityCritical]  // auto-generated
    private void FieldSetter(String typeName, String fieldName, Object val)
    {
        Contract.Requires(typeName != null); 
        Contract.Requires(fieldName != null);
 
        // Extract the field info object 
        FieldInfo fldInfo = GetFieldInfo(typeName, fieldName);
 
        if (fldInfo.IsInitOnly)
            throw new FieldAccessException(Environment.GetResourceString("FieldAccess_InitOnly"));

        // Make sure that the value is compatible with the type 
        // of field
#if FEATURE_REMOTING 
        System.Runtime.Remoting.Messaging.Message.CoerceArg(val, fldInfo.FieldType); 
#else
        Type pt=fldInfo.FieldType; 
        if (pt.IsByRef)
        {
            pt = pt.GetElementType();
        } 

        if (!pt.IsInstanceOfType(val)) 
        { 
            val = Convert.ChangeType(val, pt, CultureInfo.InvariantCulture);
        } 

#endif

        // Set the value 
        fldInfo.SetValue(this, val);
    } 
 
    // Gets the value specified in the variant on the field
    // 
    private void FieldGetter(String typeName, String fieldName, ref Object val)
    {
        Contract.Requires(typeName != null);
        Contract.Requires(fieldName != null); 

        // Extract the field info object 
        FieldInfo fldInfo = GetFieldInfo(typeName, fieldName); 

        // Get the value 
        val = fldInfo.GetValue(this);
    }

    // Gets the field info object given the type name and field name. 
    //
    private FieldInfo GetFieldInfo(String typeName, String fieldName) 
    { 
        Contract.Requires(typeName != null);
        Contract.Requires(fieldName != null); 
        Contract.Ensures(Contract.Result() != null);

        Type t = GetType();
        while(null != t) 
        {
            if(t.FullName.Equals(typeName)) 
            { 
                break;
            } 

            t = t.BaseType;
        }
 
        if (null == t)
        { 
#if FEATURE_REMOTING 
            throw new RemotingException(String.Format(
                CultureInfo.CurrentCulture, Environment.GetResourceString("Remoting_BadType"), 
                                              typeName));
#else
            throw new ArgumentException();
#endif 
        }
 
        FieldInfo fldInfo = t.GetField(fieldName, BindingFlags.Public | 
                                                  BindingFlags.Instance |
                                                  BindingFlags.IgnoreCase); 
        if(null == fldInfo)
        {
#if FEATURE_REMOTING
            throw new RemotingException(String.Format( 
                CultureInfo.CurrentCulture, Environment.GetResourceString("Remoting_BadField"),
                                              fieldName, typeName)); 
#else 
            throw new ArgumentException();
#endif 

        }

        return fldInfo; 
    }
} 
 

// Internal methodtable used to instantiate the "canonical" methodtable for generic instantiations. 
// The name "__Canon" will never been seen by users but it will appear a lot in debugger stack traces
// involving generics so it is kept deliberately short as to avoid being a nuisance.

[Serializable] 
[ClassInterface(ClassInterfaceType.AutoDual)]
[System.Runtime.InteropServices.ComVisible(true)] 
internal class __Canon 
{
} 

}

// File provided for Reference Use Only by Microsoft Corporation (c) 2007.


                        

Link Menu

Network programming in C#, Network Programming in VB.NET, Network Programming in .NET
This book is available now!
Buy at Amazon US or
Buy at Amazon UK