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
- AnimationLayer.cs
- EdmSchemaAttribute.cs
- SqlConnection.cs
- TemplateParser.cs
- Label.cs
- DefaultPrintController.cs
- SessionPageStateSection.cs
- NotImplementedException.cs
- TogglePattern.cs
- counter.cs
- ImageCodecInfo.cs
- HashHelper.cs
- HitTestWithPointDrawingContextWalker.cs
- FlowDocumentPageViewerAutomationPeer.cs
- GlyphsSerializer.cs
- ServiceNameElement.cs
- WebProxyScriptElement.cs
- RuleCache.cs
- ListSortDescription.cs
- ReadOnlyTernaryTree.cs
- ProxyWebPart.cs
- SqlNotificationRequest.cs
- DbConnectionPoolGroup.cs
- SessionParameter.cs
- XamlSerializer.cs
- AttachedAnnotation.cs
- NumberFormatInfo.cs
- IncrementalReadDecoders.cs
- brushes.cs
- RealProxy.cs
- UserThread.cs
- DataTableReaderListener.cs
- TextRunCache.cs
- DefaultPropertiesToSend.cs
- AuthenticationModuleElement.cs
- GeneralTransform3D.cs
- AppDomainShutdownMonitor.cs
- DefaultEventAttribute.cs
- BuildDependencySet.cs
- ProfileManager.cs
- InstanceNotReadyException.cs
- EFColumnProvider.cs
- CodeDelegateInvokeExpression.cs
- CustomAttributeBuilder.cs
- ZoneButton.cs
- PathSegmentCollection.cs
- HtmlInputText.cs
- BinHexDecoder.cs
- PositiveTimeSpanValidatorAttribute.cs
- ConditionalDesigner.cs
- _TLSstream.cs
- SqlConnectionHelper.cs
- OleCmdHelper.cs
- InvocationExpression.cs
- CqlErrorHelper.cs
- PointConverter.cs
- SerializationTrace.cs
- SqlInfoMessageEvent.cs
- RuntimeArgumentHandle.cs
- CompilationSection.cs
- Nullable.cs
- Hyperlink.cs
- SubclassTypeValidator.cs
- ConnectionInterfaceCollection.cs
- EditorPartChrome.cs
- IdleTimeoutMonitor.cs
- XmlHierarchicalDataSourceView.cs
- AmbiguousMatchException.cs
- SystemColors.cs
- AccessControlEntry.cs
- PrintPreviewControl.cs
- XmlParserContext.cs
- ZipPackagePart.cs
- Authorization.cs
- Model3DCollection.cs
- ClickablePoint.cs
- HtmlInputHidden.cs
- ConfigurationStrings.cs
- QfeChecker.cs
- DataRelation.cs
- UnlockInstanceCommand.cs
- DataObject.cs
- XmlReflectionImporter.cs
- CapabilitiesSection.cs
- EdmValidator.cs
- DataSourceControl.cs
- FileVersionInfo.cs
- Descriptor.cs
- DbgUtil.cs
- RawAppCommandInputReport.cs
- RawStylusActions.cs
- ConfigXmlCDataSection.cs
- OleDbErrorCollection.cs
- TdsParserSessionPool.cs
- ProgressBarRenderer.cs
- TextParaClient.cs
- WindowsTreeView.cs
- ExpressionLink.cs
- UmAlQuraCalendar.cs
- DetailsViewRowCollection.cs