bitset.cpp

来自「IBM的解析xml的工具Xerces的源代码」· C++ 代码 · 共 299 行

CPP
299
字号
/* * Copyright 1999-2000,2004 The Apache Software Foundation. *  * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at *  *      http://www.apache.org/licenses/LICENSE-2.0 *  * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. *//* * $Log: BitSet.cpp,v $ * Revision 1.4  2004/09/08 13:56:21  peiyongz * Apache License Version 2.0 * * Revision 1.3  2003/05/15 19:04:35  knoaman * Partial implementation of the configurable memory manager. * * Revision 1.2  2002/11/04 15:22:03  tng * C++ Namespace Support. * * Revision 1.1.1.1  2002/02/01 22:22:10  peiyongz * sane_include * * Revision 1.4  2000/03/02 19:54:38  roddey * This checkin includes many changes done while waiting for the * 1.1.0 code to be finished. I can't list them all here, but a list is * available elsewhere. * * Revision 1.3  2000/02/06 07:48:01  rahulj * Year 2K copyright swat. * * Revision 1.2  1999/12/15 19:38:22  roddey * Simple fix to bit ops comments * * Revision 1.1.1.1  1999/11/09 01:04:09  twl * Initial checkin * * Revision 1.2  1999/11/08 20:45:05  rahul * Swat for adding in Product name and CVS comment log variable. * */// ---------------------------------------------------------------------------//  Includes// ---------------------------------------------------------------------------#include <xercesc/util/BitSet.hpp>#include <xercesc/framework/MemoryManager.hpp>XERCES_CPP_NAMESPACE_BEGIN// ---------------------------------------------------------------------------//  Local const data////  kBitsPerUnit//      The number of bits in each of our allocation units, which is a 32//      bit value in this case.////  kGrowBy//      The minimum allocation units to grow the buffer by.// ---------------------------------------------------------------------------const unsigned int  kBitsPerUnit    = 32;const unsigned int  kGrowBy         = 1;// ---------------------------------------------------------------------------//  BitSet: Constructors and Destructor// ---------------------------------------------------------------------------BitSet::BitSet( const unsigned int size              , MemoryManager* const manager) :    fMemoryManager(manager)    , fBits(0)    , fUnitLen(0){    ensureCapacity(size);}BitSet::BitSet(const BitSet& toCopy) :    fMemoryManager(toCopy.fMemoryManager)    , fBits(0)    , fUnitLen(toCopy.fUnitLen){    fBits = (unsigned long*) fMemoryManager->allocate    (        fUnitLen * sizeof(unsigned long)    ); //new unsigned long[fUnitLen];    for (unsigned int i = 0; i < fUnitLen; i++)        fBits[i] = toCopy.fBits[i];}BitSet::~BitSet(){    fMemoryManager->deallocate(fBits); //delete [] fBits;}// ---------------------------------------------------------------------------//  BitSet: Equality methods// ---------------------------------------------------------------------------bool BitSet::equals(const BitSet& other) const{    if (this == &other)        return true;    if (fUnitLen != other.fUnitLen)        return false;    for (unsigned int i = 0; i < fUnitLen; i++)    {        if (fBits[i] != other.fBits[i])            return false;    }    return true;}// ---------------------------------------------------------------------------//  BitSet: Getter methods// ---------------------------------------------------------------------------bool BitSet::get(const unsigned int index) const{    const unsigned int unitOfBit = (index / kBitsPerUnit);    const unsigned int bitWithinUnit = index % kBitsPerUnit;    //    //  If the index is beyond our size, don't actually expand. Just return    //  false, which is what the state would be if we did expand it.    //    bool retVal = false;    if (unitOfBit <= fUnitLen)    {        if (fBits[unitOfBit] & (1 << bitWithinUnit))            retVal = true;    }    return retVal;}unsigned int BitSet::size() const{    return fUnitLen * kBitsPerUnit;}// ---------------------------------------------------------------------------//  BitSet: Setter methods// ---------------------------------------------------------------------------bool BitSet::allAreCleared() const{    for (unsigned int index = 0; index < fUnitLen; index++)    {        if (fBits[index])            return false;    }    return true;}bool BitSet::allAreSet() const{    for (unsigned int index = 0; index < fUnitLen; index++)    {        if (fBits[index] != 0xFFFFFFFF)            return false;    }    return true;}void BitSet::clearAll(){    // Just zero out all the units    for (unsigned int index = 0; index < fUnitLen; index++)        fBits[index] = 0;}void BitSet::clear(const unsigned int index){    ensureCapacity(index+1);    const int unitOfBit = (index / kBitsPerUnit);    const int bitWithinUnit = index % kBitsPerUnit;    fBits[unitOfBit] &= ~(1UL << bitWithinUnit);}void BitSet::set(const unsigned int index){    ensureCapacity(index+1);    const int unitOfBit = (index / kBitsPerUnit);    const int bitWithinUnit = index % kBitsPerUnit;    fBits[unitOfBit] |= (1UL << bitWithinUnit);}// ---------------------------------------------------------------------------//  BitSet: Bitwise logical methods// ---------------------------------------------------------------------------void BitSet::andWith(const BitSet& other){    if (fUnitLen < other.fUnitLen)        ensureCapacity(other.fUnitLen * kBitsPerUnit);    for (unsigned int index = 0; index < other.fUnitLen; index++)        fBits[index] &= other.fBits[index];}void BitSet::orWith(const BitSet& other){    if (fUnitLen < other.fUnitLen)        ensureCapacity(other.fUnitLen * kBitsPerUnit);    for (unsigned int index = 0; index < other.fUnitLen; index++)        fBits[index] |= other.fBits[index];}void BitSet::xorWith(const BitSet& other){    if (fUnitLen < other.fUnitLen)        ensureCapacity(other.fUnitLen * kBitsPerUnit);    for (unsigned int index = 0; index < other.fUnitLen; index++)        fBits[index] ^= other.fBits[index];}// ---------------------------------------------------------------------------//  BitSet: Miscellaneous methods// ---------------------------------------------------------------------------unsigned int BitSet::hash(const unsigned int hashModulus) const{    const unsigned char* pBytes = (const unsigned char*)fBits;    const int unsigned len = fUnitLen * sizeof(unsigned long);    unsigned int  hashVal = 0;    for (unsigned int index = 0; index < len; index++)    {        hashVal <<= 1;        hashVal ^= *pBytes;    }    return hashVal % hashModulus;}// ---------------------------------------------------------------------------//  BitSet: Private methods// ---------------------------------------------------------------------------void BitSet::ensureCapacity(const unsigned int size){    // Calculate the units required to hold the passed bit count.    unsigned int unitsNeeded = size / kBitsPerUnit;    if (size % kBitsPerUnit)        unitsNeeded++;    // If its more than we have, then reallocate    if (unitsNeeded > fUnitLen)    {        // Regrow the unit length by at least the expansion unit        if (unitsNeeded < (fUnitLen + kGrowBy))            unitsNeeded = fUnitLen + kGrowBy;        // Allocate the array, copy the old stuff, and zero the new stuff        unsigned long* newBits = (unsigned long*) fMemoryManager->allocate        (            unitsNeeded * sizeof(unsigned long)        ); //new unsigned long[unitsNeeded];        unsigned int index;        for (index = 0; index < fUnitLen; index++)            newBits[index] = fBits[index];        for (; index < unitsNeeded; index++)            newBits[index] = 0;        fMemoryManager->deallocate(fBits); //delete [] fBits;        fBits = newBits;        fUnitLen = unitsNeeded;    }}XERCES_CPP_NAMESPACE_END

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?