Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / clr / src / BCL / System / UInt64.cs / 1305376 / UInt64.cs
// ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== /*============================================================ ** ** Class: UInt64 ** ** Purpose: This class will encapsulate an unsigned long and ** provide an Object representation of it. ** ** ===========================================================*/ namespace System { using System.Globalization; using System; ///#if GENERICS_WORK /// using System.Numerics; ///#endif using System.Runtime.InteropServices; using System.Diagnostics.Contracts; // Wrapper for unsigned 64 bit integers. [Serializable] [CLSCompliant(false), System.Runtime.InteropServices.StructLayout(LayoutKind.Sequential)] [System.Runtime.InteropServices.ComVisible(true)] #if GENERICS_WORK public struct UInt64 : IComparable, IFormattable, IConvertible , IComparable, IEquatable /// , IArithmetic #if false // ugly hack to fix syntax for TrimSrc parser, which ignores #if directives { } #endif #else public struct UInt64 : IComparable, IFormattable, IConvertible #endif { private ulong m_value; public const ulong MaxValue = (ulong) 0xffffffffffffffffL; public const ulong MinValue = 0x0; // Compares this object to another object, returning an integer that // indicates the relationship. // Returns a value less than zero if this object // null is considered to be less than any instance. // If object is not of type UInt64, this method throws an ArgumentException. // public int CompareTo(Object value) { if (value == null) { return 1; } if (value is UInt64) { // Need to use compare because subtraction will wrap // to positive for very large neg numbers, etc. ulong i = (ulong)value; if (m_value < i) return -1; if (m_value > i) return 1; return 0; } throw new ArgumentException (Environment.GetResourceString("Arg_MustBeUInt64")); } public int CompareTo(UInt64 value) { // Need to use compare because subtraction will wrap // to positive for very large neg numbers, etc. if (m_value < value) return -1; if (m_value > value) return 1; return 0; } public override bool Equals(Object obj) { if (!(obj is UInt64)) { return false; } return m_value == ((UInt64)obj).m_value; } public bool Equals(UInt64 obj) { return m_value == obj; } // The value of the lower 32 bits XORed with the uppper 32 bits. public override int GetHashCode() { return ((int)m_value) ^ (int)(m_value >> 32); } [System.Security.SecuritySafeCritical] // auto-generated public override String ToString() { Contract.Ensures(Contract.Result () != null); return Number.FormatUInt64(m_value, null, NumberFormatInfo.CurrentInfo); } [System.Security.SecuritySafeCritical] // auto-generated public String ToString(IFormatProvider provider) { Contract.Ensures(Contract.Result () != null); return Number.FormatUInt64(m_value, null, NumberFormatInfo.GetInstance(provider)); } [System.Security.SecuritySafeCritical] // auto-generated public String ToString(String format) { Contract.Ensures(Contract.Result () != null); return Number.FormatUInt64(m_value, format, NumberFormatInfo.CurrentInfo); } [System.Security.SecuritySafeCritical] // auto-generated public String ToString(String format, IFormatProvider provider) { Contract.Ensures(Contract.Result () != null); return Number.FormatUInt64(m_value, format, NumberFormatInfo.GetInstance(provider)); } [CLSCompliant(false)] public static ulong Parse(String s) { return Number.ParseUInt64(s, NumberStyles.Integer, NumberFormatInfo.CurrentInfo); } [CLSCompliant(false)] public static ulong Parse(String s, NumberStyles style) { NumberFormatInfo.ValidateParseStyleInteger(style); return Number.ParseUInt64(s, style, NumberFormatInfo.CurrentInfo); } [CLSCompliant(false)] public static ulong Parse(string s, IFormatProvider provider) { return Number.ParseUInt64(s, NumberStyles.Integer, NumberFormatInfo.GetInstance(provider)); } [CLSCompliant(false)] public static ulong Parse(String s, NumberStyles style, IFormatProvider provider) { NumberFormatInfo.ValidateParseStyleInteger(style); return Number.ParseUInt64(s, style, NumberFormatInfo.GetInstance(provider)); } [System.Security.SecuritySafeCritical] // auto-generated [CLSCompliant(false)] public static Boolean TryParse(String s, out UInt64 result) { return Number.TryParseUInt64(s, NumberStyles.Integer, NumberFormatInfo.CurrentInfo, out result); } [System.Security.SecuritySafeCritical] // auto-generated [CLSCompliant(false)] public static Boolean TryParse(String s, NumberStyles style, IFormatProvider provider, out UInt64 result) { NumberFormatInfo.ValidateParseStyleInteger(style); return Number.TryParseUInt64(s, style, NumberFormatInfo.GetInstance(provider), out result); } // // IConvertible implementation // public TypeCode GetTypeCode() { return TypeCode.UInt64; } /// bool IConvertible.ToBoolean(IFormatProvider provider) { return Convert.ToBoolean(m_value); } /// char IConvertible.ToChar(IFormatProvider provider) { return Convert.ToChar(m_value); } /// sbyte IConvertible.ToSByte(IFormatProvider provider) { return Convert.ToSByte(m_value); } /// byte IConvertible.ToByte(IFormatProvider provider) { return Convert.ToByte(m_value); } /// short IConvertible.ToInt16(IFormatProvider provider) { return Convert.ToInt16(m_value); } /// ushort IConvertible.ToUInt16(IFormatProvider provider) { return Convert.ToUInt16(m_value); } /// int IConvertible.ToInt32(IFormatProvider provider) { return Convert.ToInt32(m_value); } /// uint IConvertible.ToUInt32(IFormatProvider provider) { return Convert.ToUInt32(m_value); } /// long IConvertible.ToInt64(IFormatProvider provider) { return Convert.ToInt64(m_value); } /// ulong IConvertible.ToUInt64(IFormatProvider provider) { return m_value; } /// float IConvertible.ToSingle(IFormatProvider provider) { return Convert.ToSingle(m_value); } /// double IConvertible.ToDouble(IFormatProvider provider) { return Convert.ToDouble(m_value); } /// Decimal IConvertible.ToDecimal(IFormatProvider provider) { return Convert.ToDecimal(m_value); } /// DateTime IConvertible.ToDateTime(IFormatProvider provider) { throw new InvalidCastException(Environment.GetResourceString("InvalidCast_FromTo", "UInt64", "DateTime")); } /// Object IConvertible.ToType(Type type, IFormatProvider provider) { return Convert.DefaultToType((IConvertible)this, type, provider); } ///#if GENERICS_WORK /// // /// // IArithmetic implementation /// // /// /// /// /// UInt64 IArithmetic .AbsoluteValue(out bool overflowed) { /// overflowed = false; /// return m_value; /// } /// /// /// /// UInt64 IArithmetic .Negate(out bool overflowed) { /// overflowed = (m_value != 0); /// return m_value; /// } /// /// /// /// UInt64 IArithmetic .Sign(out bool overflowed) { /// overflowed = false; /// return (UInt64)(m_value > 0 ? 1 : 0); /// } /// /// /// /// UInt64 IArithmetic .Add(UInt64 addend, out bool overflowed) { /// // /// // true arithmetic range check => re-written for unsigned int /// // ------------------------------- ------------------------------- /// // ((m_value + addend) > MaxValue) => (m_value > (MaxValue - addend)) /// // /// /// overflowed = (m_value > (MaxValue - addend)); /// return unchecked(m_value + addend); /// } /// /// /// /// UInt64 IArithmetic .Subtract(UInt64 subtrahend, out bool overflowed) { /// // /// // true arithmetic range check => re-written for unsigned int /// // ------------------------------- ------------------------------- /// // ((m_value - subtrahend) < MinValue) => (m_value < (MinValue + subtrahend)) /// // /// /// overflowed = (m_value < (MinValue + subtrahend)); /// return unchecked(m_value - subtrahend); /// } /// /// /// /// UInt64 IArithmetic .Multiply(UInt64 multiplier, out bool overflowed) { /// // /// // true arithmetic range check => re-written for unsigned int /// // ------------------------------- ------------------------------- /// // ((m_value * multiplier) > MaxValue) => (multiplier != 0) && (m_value > (MaxValue / multiplier)) /// // /// /// overflowed = (multiplier != 0) && (m_value > (MaxValue / multiplier)); /// return unchecked(m_value * multiplier); /// } /// /// /// /// /// UInt64 IArithmetic .Divide(UInt64 divisor, out bool overflowed) { /// overflowed = false; /// return checked(m_value / divisor); // can throw DivideByZeroException /// } /// /// /// /// UInt64 IArithmetic .DivideRemainder(UInt64 divisor, out UInt64 remainder, out bool overflowed) { /// overflowed = false; /// remainder = (m_value % divisor); /// return checked(m_value / divisor); // can throw DivideByZeroException /// } /// /// /// /// UInt64 IArithmetic .Remainder(UInt64 divisor, out bool overflowed) { /// overflowed = false; /// return (m_value % divisor); /// } /// /// /// /// ArithmeticDescriptor IArithmetic .GetDescriptor() { /// if (s_descriptor == null) { /// s_descriptor = new UInt64ArithmeticDescriptor( ArithmeticCapabilities.One /// | ArithmeticCapabilities.Zero /// | ArithmeticCapabilities.MaxValue /// | ArithmeticCapabilities.MinValue /// | ArithmeticCapabilities.Unsigned); /// } /// return s_descriptor; /// } /// /// private static UInt64ArithmeticDescriptor s_descriptor; /// /// class UInt64ArithmeticDescriptor : ArithmeticDescriptor { /// public UInt64ArithmeticDescriptor(ArithmeticCapabilities capabilities) : base(capabilities) {} /// /// public override UInt64 One { /// get { /// return (UInt64) 1; /// } /// } /// /// public override UInt64 Zero { /// get { /// return (UInt64) 0; /// } /// } /// /// public override UInt64 MinValue { /// get { /// return UInt64.MinValue; /// } /// } /// /// public override UInt64 MaxValue { /// get { /// return UInt64.MaxValue; /// } /// } /// } ///#endif // #if GENERICS_WORK } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== /*============================================================ ** ** Class: UInt64 ** ** Purpose: This class will encapsulate an unsigned long and ** provide an Object representation of it. ** ** ===========================================================*/ namespace System { using System.Globalization; using System; ///#if GENERICS_WORK /// using System.Numerics; ///#endif using System.Runtime.InteropServices; using System.Diagnostics.Contracts; // Wrapper for unsigned 64 bit integers. [Serializable] [CLSCompliant(false), System.Runtime.InteropServices.StructLayout(LayoutKind.Sequential)] [System.Runtime.InteropServices.ComVisible(true)] #if GENERICS_WORK public struct UInt64 : IComparable, IFormattable, IConvertible , IComparable , IEquatable /// , IArithmetic #if false // ugly hack to fix syntax for TrimSrc parser, which ignores #if directives { } #endif #else public struct UInt64 : IComparable, IFormattable, IConvertible #endif { private ulong m_value; public const ulong MaxValue = (ulong) 0xffffffffffffffffL; public const ulong MinValue = 0x0; // Compares this object to another object, returning an integer that // indicates the relationship. // Returns a value less than zero if this object // null is considered to be less than any instance. // If object is not of type UInt64, this method throws an ArgumentException. // public int CompareTo(Object value) { if (value == null) { return 1; } if (value is UInt64) { // Need to use compare because subtraction will wrap // to positive for very large neg numbers, etc. ulong i = (ulong)value; if (m_value < i) return -1; if (m_value > i) return 1; return 0; } throw new ArgumentException (Environment.GetResourceString("Arg_MustBeUInt64")); } public int CompareTo(UInt64 value) { // Need to use compare because subtraction will wrap // to positive for very large neg numbers, etc. if (m_value < value) return -1; if (m_value > value) return 1; return 0; } public override bool Equals(Object obj) { if (!(obj is UInt64)) { return false; } return m_value == ((UInt64)obj).m_value; } public bool Equals(UInt64 obj) { return m_value == obj; } // The value of the lower 32 bits XORed with the uppper 32 bits. public override int GetHashCode() { return ((int)m_value) ^ (int)(m_value >> 32); } [System.Security.SecuritySafeCritical] // auto-generated public override String ToString() { Contract.Ensures(Contract.Result () != null); return Number.FormatUInt64(m_value, null, NumberFormatInfo.CurrentInfo); } [System.Security.SecuritySafeCritical] // auto-generated public String ToString(IFormatProvider provider) { Contract.Ensures(Contract.Result () != null); return Number.FormatUInt64(m_value, null, NumberFormatInfo.GetInstance(provider)); } [System.Security.SecuritySafeCritical] // auto-generated public String ToString(String format) { Contract.Ensures(Contract.Result () != null); return Number.FormatUInt64(m_value, format, NumberFormatInfo.CurrentInfo); } [System.Security.SecuritySafeCritical] // auto-generated public String ToString(String format, IFormatProvider provider) { Contract.Ensures(Contract.Result () != null); return Number.FormatUInt64(m_value, format, NumberFormatInfo.GetInstance(provider)); } [CLSCompliant(false)] public static ulong Parse(String s) { return Number.ParseUInt64(s, NumberStyles.Integer, NumberFormatInfo.CurrentInfo); } [CLSCompliant(false)] public static ulong Parse(String s, NumberStyles style) { NumberFormatInfo.ValidateParseStyleInteger(style); return Number.ParseUInt64(s, style, NumberFormatInfo.CurrentInfo); } [CLSCompliant(false)] public static ulong Parse(string s, IFormatProvider provider) { return Number.ParseUInt64(s, NumberStyles.Integer, NumberFormatInfo.GetInstance(provider)); } [CLSCompliant(false)] public static ulong Parse(String s, NumberStyles style, IFormatProvider provider) { NumberFormatInfo.ValidateParseStyleInteger(style); return Number.ParseUInt64(s, style, NumberFormatInfo.GetInstance(provider)); } [System.Security.SecuritySafeCritical] // auto-generated [CLSCompliant(false)] public static Boolean TryParse(String s, out UInt64 result) { return Number.TryParseUInt64(s, NumberStyles.Integer, NumberFormatInfo.CurrentInfo, out result); } [System.Security.SecuritySafeCritical] // auto-generated [CLSCompliant(false)] public static Boolean TryParse(String s, NumberStyles style, IFormatProvider provider, out UInt64 result) { NumberFormatInfo.ValidateParseStyleInteger(style); return Number.TryParseUInt64(s, style, NumberFormatInfo.GetInstance(provider), out result); } // // IConvertible implementation // public TypeCode GetTypeCode() { return TypeCode.UInt64; } /// bool IConvertible.ToBoolean(IFormatProvider provider) { return Convert.ToBoolean(m_value); } /// char IConvertible.ToChar(IFormatProvider provider) { return Convert.ToChar(m_value); } /// sbyte IConvertible.ToSByte(IFormatProvider provider) { return Convert.ToSByte(m_value); } /// byte IConvertible.ToByte(IFormatProvider provider) { return Convert.ToByte(m_value); } /// short IConvertible.ToInt16(IFormatProvider provider) { return Convert.ToInt16(m_value); } /// ushort IConvertible.ToUInt16(IFormatProvider provider) { return Convert.ToUInt16(m_value); } /// int IConvertible.ToInt32(IFormatProvider provider) { return Convert.ToInt32(m_value); } /// uint IConvertible.ToUInt32(IFormatProvider provider) { return Convert.ToUInt32(m_value); } /// long IConvertible.ToInt64(IFormatProvider provider) { return Convert.ToInt64(m_value); } /// ulong IConvertible.ToUInt64(IFormatProvider provider) { return m_value; } /// float IConvertible.ToSingle(IFormatProvider provider) { return Convert.ToSingle(m_value); } /// double IConvertible.ToDouble(IFormatProvider provider) { return Convert.ToDouble(m_value); } /// Decimal IConvertible.ToDecimal(IFormatProvider provider) { return Convert.ToDecimal(m_value); } /// DateTime IConvertible.ToDateTime(IFormatProvider provider) { throw new InvalidCastException(Environment.GetResourceString("InvalidCast_FromTo", "UInt64", "DateTime")); } /// Object IConvertible.ToType(Type type, IFormatProvider provider) { return Convert.DefaultToType((IConvertible)this, type, provider); } ///#if GENERICS_WORK /// // /// // IArithmetic implementation /// // /// /// /// /// UInt64 IArithmetic .AbsoluteValue(out bool overflowed) { /// overflowed = false; /// return m_value; /// } /// /// /// /// UInt64 IArithmetic .Negate(out bool overflowed) { /// overflowed = (m_value != 0); /// return m_value; /// } /// /// /// /// UInt64 IArithmetic .Sign(out bool overflowed) { /// overflowed = false; /// return (UInt64)(m_value > 0 ? 1 : 0); /// } /// /// /// /// UInt64 IArithmetic .Add(UInt64 addend, out bool overflowed) { /// // /// // true arithmetic range check => re-written for unsigned int /// // ------------------------------- ------------------------------- /// // ((m_value + addend) > MaxValue) => (m_value > (MaxValue - addend)) /// // /// /// overflowed = (m_value > (MaxValue - addend)); /// return unchecked(m_value + addend); /// } /// /// /// /// UInt64 IArithmetic .Subtract(UInt64 subtrahend, out bool overflowed) { /// // /// // true arithmetic range check => re-written for unsigned int /// // ------------------------------- ------------------------------- /// // ((m_value - subtrahend) < MinValue) => (m_value < (MinValue + subtrahend)) /// // /// /// overflowed = (m_value < (MinValue + subtrahend)); /// return unchecked(m_value - subtrahend); /// } /// /// /// /// UInt64 IArithmetic .Multiply(UInt64 multiplier, out bool overflowed) { /// // /// // true arithmetic range check => re-written for unsigned int /// // ------------------------------- ------------------------------- /// // ((m_value * multiplier) > MaxValue) => (multiplier != 0) && (m_value > (MaxValue / multiplier)) /// // /// /// overflowed = (multiplier != 0) && (m_value > (MaxValue / multiplier)); /// return unchecked(m_value * multiplier); /// } /// /// /// /// /// UInt64 IArithmetic .Divide(UInt64 divisor, out bool overflowed) { /// overflowed = false; /// return checked(m_value / divisor); // can throw DivideByZeroException /// } /// /// /// /// UInt64 IArithmetic .DivideRemainder(UInt64 divisor, out UInt64 remainder, out bool overflowed) { /// overflowed = false; /// remainder = (m_value % divisor); /// return checked(m_value / divisor); // can throw DivideByZeroException /// } /// /// /// /// UInt64 IArithmetic .Remainder(UInt64 divisor, out bool overflowed) { /// overflowed = false; /// return (m_value % divisor); /// } /// /// /// /// ArithmeticDescriptor IArithmetic .GetDescriptor() { /// if (s_descriptor == null) { /// s_descriptor = new UInt64ArithmeticDescriptor( ArithmeticCapabilities.One /// | ArithmeticCapabilities.Zero /// | ArithmeticCapabilities.MaxValue /// | ArithmeticCapabilities.MinValue /// | ArithmeticCapabilities.Unsigned); /// } /// return s_descriptor; /// } /// /// private static UInt64ArithmeticDescriptor s_descriptor; /// /// class UInt64ArithmeticDescriptor : ArithmeticDescriptor { /// public UInt64ArithmeticDescriptor(ArithmeticCapabilities capabilities) : base(capabilities) {} /// /// public override UInt64 One { /// get { /// return (UInt64) 1; /// } /// } /// /// public override UInt64 Zero { /// get { /// return (UInt64) 0; /// } /// } /// /// public override UInt64 MinValue { /// get { /// return UInt64.MinValue; /// } /// } /// /// public override UInt64 MaxValue { /// get { /// return UInt64.MaxValue; /// } /// } /// } ///#endif // #if GENERICS_WORK } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- InputScopeConverter.cs
- PointLightBase.cs
- BindToObject.cs
- InputReport.cs
- DataViewListener.cs
- FormatVersion.cs
- WebPartRestoreVerb.cs
- BitmapVisualManager.cs
- UrlAuthFailureHandler.cs
- ProfileSection.cs
- Button.cs
- CodeAttributeArgument.cs
- AvTraceFormat.cs
- SafeRsaProviderHandle.cs
- Cursors.cs
- relpropertyhelper.cs
- SequenceNumber.cs
- SafeSecurityHandles.cs
- DataContractJsonSerializer.cs
- TripleDESCryptoServiceProvider.cs
- WebHttpBinding.cs
- FileEnumerator.cs
- EntityStoreSchemaGenerator.cs
- SHA384Managed.cs
- oledbmetadatacolumnnames.cs
- DataGridAutoGeneratingColumnEventArgs.cs
- WebExceptionStatus.cs
- AudioStateChangedEventArgs.cs
- ImageClickEventArgs.cs
- NameTable.cs
- XmlCharCheckingReader.cs
- EmissiveMaterial.cs
- WSSecurityXXX2005.cs
- CodePageEncoding.cs
- WebPermission.cs
- UnSafeCharBuffer.cs
- XmlDownloadManager.cs
- MatrixCamera.cs
- DateTimeValueSerializerContext.cs
- XamlSerializationHelper.cs
- DelegatingChannelListener.cs
- CodeAccessSecurityEngine.cs
- LogArchiveSnapshot.cs
- PropertyEntry.cs
- ObjectStorage.cs
- StylusButtonEventArgs.cs
- TextFormattingConverter.cs
- DbCommandTree.cs
- PreviewPrintController.cs
- DependencyObjectPropertyDescriptor.cs
- securitycriticaldata.cs
- StringExpressionSet.cs
- SessionState.cs
- RightsManagementEncryptedStream.cs
- DbProviderFactories.cs
- ThaiBuddhistCalendar.cs
- HandlerBase.cs
- XmlQueryContext.cs
- DiscriminatorMap.cs
- ProviderConnectionPointCollection.cs
- ConnectionInterfaceCollection.cs
- Style.cs
- ApplicationServiceHelper.cs
- RightNameExpirationInfoPair.cs
- TreeNodeClickEventArgs.cs
- DataGridViewColumnDividerDoubleClickEventArgs.cs
- CardSpaceSelector.cs
- ClipboardData.cs
- StringStorage.cs
- OutOfProcStateClientManager.cs
- StringCollection.cs
- InputReport.cs
- DataGridViewAccessibleObject.cs
- FontConverter.cs
- MatrixUtil.cs
- TableLayoutRowStyleCollection.cs
- CompModSwitches.cs
- ModifierKeysValueSerializer.cs
- ByteAnimationBase.cs
- UIntPtr.cs
- HtmlTableCellCollection.cs
- ContentType.cs
- TimelineGroup.cs
- HtmlInputControl.cs
- ErrorProvider.cs
- ReadWriteSpinLock.cs
- OverflowException.cs
- DodSequenceMerge.cs
- Panel.cs
- XmlUtilWriter.cs
- SecurityKeyIdentifier.cs
- RunWorkerCompletedEventArgs.cs
- BitmapCodecInfo.cs
- UndoManager.cs
- MouseGesture.cs
- AsyncPostBackErrorEventArgs.cs
- UIElementIsland.cs
- documentation.cs
- Int32Collection.cs
- PropertyEmitter.cs