本文共 856 字,大约阅读时间需要 2 分钟。
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(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 (pAddr); if(_pHead->_cVersion != BM_VERSION) { return -1; } if(iSize != _pHead->_iMemSize) { return -2; } _pData = (unsigned char*)pAddr + sizeof(tagBitMapHead); return 0;}
转载地址:http://agwti.baihongyu.com/