bitmap的概念, 在之前博客中多次提及, 并且给出了代码, 在处理海量数据时, 会有内存优势。想起来了, 我在某面试中, 还被问过这个问题。
tc_bitmap就是专门做bitmap处理的, 看了一下源码, 无非就是bit的set, get, clear操作。看似眼花缭乱, 实则很简单。
tc_bitmap是tars的基础工具, 但tars代码中并没有用到tc_bitmap, 所以我们也就不用过于关注, 但这并不是说bitmap不重要。 看过linux源码的人都知道, 在linux源码中, bitmap到处可见, 实际上, 就是一种基本的数据结构。
来窥探下, 就去睡觉:
void TC_BitMap::BitMap::create(void *pAddr, size_t iSize)
{
memset((char*)pAddr, 0, iSize);
_pHead = static_cast<tagBitMapHead*>(pAddr);
_pHead->_cVersion = BM_VERSION;
_pHead->_iMemSize = iSize;
_pData = (unsigned char*)pAddr + sizeof(tagBitMapHead);
}
int TC_BitMap::BitMap::connect(void *pAddr, size_t iSize)
{
_pHead = static_cast<tagBitMapHead*>(pAddr);
if(_pHead->_cVersion != BM_VERSION)
{
return -1;
}
if(iSize != _pHead->_iMemSize)
{
return -2;
}
_pData = (unsigned char*)pAddr + sizeof(tagBitMapHead);
return 0;
}