Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / whidbey / netfxsp / ndp / fx / src / Xml / System / Xml / Bits.cs / 1 / Bits.cs
//------------------------------------------------------------------------------
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
// [....]
//-----------------------------------------------------------------------------
namespace System.Xml {
using System;
using System.Diagnostics;
///
/// Contains static utility methods used to manipulate bits in a word.
///
internal static class Bits {
private static readonly uint MASK_0101010101010101 = 0x55555555;
private static readonly uint MASK_0011001100110011 = 0x33333333;
private static readonly uint MASK_0000111100001111 = 0x0f0f0f0f;
private static readonly uint MASK_0000000011111111 = 0x00ff00ff;
private static readonly uint MASK_1111111111111111 = 0x0000ffff;
///
/// Returns the number of 1 bits in an unsigned integer. Counts bits by divide-and-conquer method,
/// first computing 16 2-bit counts, then 8 4-bit counts, then 4 8-bit counts, then 2 16-bit counts,
/// and finally 1 32-bit count.
///
public static int Count(uint num) {
num = (num & MASK_0101010101010101) + ((num >> 1) & MASK_0101010101010101);
num = (num & MASK_0011001100110011) + ((num >> 2) & MASK_0011001100110011);
num = (num & MASK_0000111100001111) + ((num >> 4) & MASK_0000111100001111);
num = (num & MASK_0000000011111111) + ((num >> 8) & MASK_0000000011111111);
num = (num & MASK_1111111111111111) + (num >> 16);
return (int) num;
}
///
/// Returns true if the unsigned integer has exactly one bit set.
///
public static bool ExactlyOne(uint num) {
return num != 0 && (num & (num - 1)) == 0;
}
///
/// Returns true if the unsigned integer has more than one bit set.
///
public static bool MoreThanOne(uint num) {
return (num & (num - 1)) != 0;
}
///
/// Clear the least significant bit that is set and return the result.
///
public static uint ClearLeast(uint num) {
return num & (num - 1);
}
///
/// Compute the 1-based position of the least sigificant bit that is set, and return it (return 0 if no bits are set).
/// (e.g. 0x1001100 will return 3, since the 3rd bit is set).
///
public static int LeastPosition(uint num) {
if (num == 0) return 0;
return Count(num ^ (num - 1));
}
}
}
// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
//------------------------------------------------------------------------------
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
// [....]
//-----------------------------------------------------------------------------
namespace System.Xml {
using System;
using System.Diagnostics;
///
/// Contains static utility methods used to manipulate bits in a word.
///
internal static class Bits {
private static readonly uint MASK_0101010101010101 = 0x55555555;
private static readonly uint MASK_0011001100110011 = 0x33333333;
private static readonly uint MASK_0000111100001111 = 0x0f0f0f0f;
private static readonly uint MASK_0000000011111111 = 0x00ff00ff;
private static readonly uint MASK_1111111111111111 = 0x0000ffff;
///
/// Returns the number of 1 bits in an unsigned integer. Counts bits by divide-and-conquer method,
/// first computing 16 2-bit counts, then 8 4-bit counts, then 4 8-bit counts, then 2 16-bit counts,
/// and finally 1 32-bit count.
///
public static int Count(uint num) {
num = (num & MASK_0101010101010101) + ((num >> 1) & MASK_0101010101010101);
num = (num & MASK_0011001100110011) + ((num >> 2) & MASK_0011001100110011);
num = (num & MASK_0000111100001111) + ((num >> 4) & MASK_0000111100001111);
num = (num & MASK_0000000011111111) + ((num >> 8) & MASK_0000000011111111);
num = (num & MASK_1111111111111111) + (num >> 16);
return (int) num;
}
///
/// Returns true if the unsigned integer has exactly one bit set.
///
public static bool ExactlyOne(uint num) {
return num != 0 && (num & (num - 1)) == 0;
}
///
/// Returns true if the unsigned integer has more than one bit set.
///
public static bool MoreThanOne(uint num) {
return (num & (num - 1)) != 0;
}
///
/// Clear the least significant bit that is set and return the result.
///
public static uint ClearLeast(uint num) {
return num & (num - 1);
}
///
/// Compute the 1-based position of the least sigificant bit that is set, and return it (return 0 if no bits are set).
/// (e.g. 0x1001100 will return 3, since the 3rd bit is set).
///
public static int LeastPosition(uint num) {
if (num == 0) return 0;
return Count(num ^ (num - 1));
}
}
}
// 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
- DriveInfo.cs
- XsltArgumentList.cs
- PageContent.cs
- ObjectAnimationBase.cs
- ObjectViewEntityCollectionData.cs
- OrthographicCamera.cs
- Array.cs
- TableLayoutPanelCellPosition.cs
- XmlMapping.cs
- WorkItem.cs
- Parameter.cs
- ResourceFallbackManager.cs
- PathNode.cs
- CapabilitiesPattern.cs
- COAUTHIDENTITY.cs
- UrlPath.cs
- _LazyAsyncResult.cs
- Empty.cs
- DefaultCommandExtensionCallback.cs
- XmlWrappingWriter.cs
- HitTestParameters.cs
- ExtensionFile.cs
- FlowDocumentScrollViewerAutomationPeer.cs
- ExtensionQuery.cs
- EventLogQuery.cs
- EmptyEnumerator.cs
- BaseComponentEditor.cs
- TableLayoutSettings.cs
- XdrBuilder.cs
- ProcessHostConfigUtils.cs
- SupportingTokenProviderSpecification.cs
- WindowsListViewGroupHelper.cs
- SQLGuid.cs
- TemplateManager.cs
- XmlSchemas.cs
- PresentationTraceSources.cs
- NetworkStream.cs
- DataGridViewAutoSizeModeEventArgs.cs
- WindowsSpinner.cs
- MorphHelper.cs
- MailBnfHelper.cs
- RadioButtonBaseAdapter.cs
- UIElementParaClient.cs
- DictionaryBase.cs
- StringOutput.cs
- OracleRowUpdatingEventArgs.cs
- SmiEventSink_Default.cs
- PolyQuadraticBezierSegment.cs
- PrintingPermission.cs
- CheckoutException.cs
- DataGridCaption.cs
- Thickness.cs
- SafeProcessHandle.cs
- Setter.cs
- SqlCharStream.cs
- AxHostDesigner.cs
- WebBrowsableAttribute.cs
- DoubleLink.cs
- updatecommandorderer.cs
- DataGridViewCellMouseEventArgs.cs
- TextFormatter.cs
- ConfigurationLockCollection.cs
- EnumBuilder.cs
- MenuEventArgs.cs
- HScrollBar.cs
- ErrorTableItemStyle.cs
- SystemWebSectionGroup.cs
- SequentialUshortCollection.cs
- TextHintingModeValidation.cs
- FixedDocument.cs
- XhtmlConformanceSection.cs
- BaseParser.cs
- TextSpanModifier.cs
- HtmlLink.cs
- SslStreamSecurityElement.cs
- RijndaelManaged.cs
- sqlstateclientmanager.cs
- SemanticKeyElement.cs
- BaseCollection.cs
- RunClient.cs
- OracleCommandSet.cs
- InfoCardRSAPKCS1SignatureDeformatter.cs
- ModelItemCollectionImpl.cs
- ValidationService.cs
- Int16Storage.cs
- CompositionTarget.cs
- XmlNodeChangedEventArgs.cs
- OptionUsage.cs
- CodeCastExpression.cs
- CalendarBlackoutDatesCollection.cs
- InkSerializer.cs
- LayoutInformation.cs
- DiagnosticTrace.cs
- GuidConverter.cs
- NullRuntimeConfig.cs
- ArglessEventHandlerProxy.cs
- DrawingImage.cs
- XpsResource.cs
- SmtpException.cs
- SafeFileMappingHandle.cs