本文整理汇总了C++中pool类的典型用法代码示例。如果您正苦于以下问题:C++ pool类的具体用法?C++ pool怎么用?C++ pool使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了pool类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1:
~iuPool()
{
// すべて解放する
for( pool::iterator it=m_pool.begin(); it != m_pool.end(); )
{
value_ptr p = *it;
it = m_pool.erase(it);
delete p;
}
}
示例2: PortID_t
void InterConnection::test()
{
TestMessage* t;
for (ushort i = 0; i < rPolicy->getnRouters(); i++) {
t = tmpool.out();
t->init(i, PortID_t(100), 0, PortID_t(101), Message::RCV_AND_PASS);
t->setSize(100);
routers[i]->launchMsg(t);
t = tmpool.out();
t->init(i, PortID_t(100), 0, PortID_t(101), Message::RCV);
t->setSize(100);
routers[i]->launchMsg(t);
}
}
示例3: is_from
static bool is_from(void * const ptr)
{ //! Equivalent to SingletonPool::p.is_from(chunk); synchronized.
//! \returns true if chunk is from SingletonPool::is_from(chunk)
pool_type & p = get_pool();
details::pool::guard<Mutex> g(p);
return p.is_from(ptr);
}
示例4: alloc_node
node* alloc_node(node* lptr, node* rptr, T const& v,
tag_t ltag = 0, tag_t rtag = 0)
{
node* chunk = pool_.allocate();
new (chunk) node(lptr, rptr, v, ltag, rtag);
return chunk;
}
示例5: LOG
void TestMessage::garbageCollect()
{
refCount--;
if (refCount == 0) {
LOG("destroying TestMessage");
tmpool.in(this);
}
}
示例6: push
void push(value_ptr ptr) { m_pool.push_back(ptr); }
示例7: purge_memory
static bool purge_memory()
{ //! Equivalent to SingletonPool::p.purge_memory(); synchronized.
pool_type & p = get_pool();
details::pool::guard<Mutex> g(p);
return p.purge_memory();
}
示例8: dealloc_node
void dealloc_node(node* n)
{
n->~node();
pool_.deallocate(n);
}
示例9: ordered_free
static void ordered_free(void * const ptr, const size_type n)
{ //! Equivalent to SingletonPool::p.ordered_free(chunk, n); synchronized.
pool_type & p = get_pool();
details::pool::guard<Mutex> g(p);
p.ordered_free(ptr, n);
}
示例10: ordered_malloc
static void * ordered_malloc(const size_type n)
{ //! Equivalent to SingletonPool::p.ordered_malloc(n); synchronized.
pool_type & p = get_pool();
details::pool::guard<Mutex> g(p);
return p.ordered_malloc(n);
}
示例11: buffer
buffer_ptr buffer()
{
return buffer_ptr(m_pool.get(), m_deleter);
}
示例12: new
void *SmallObject::operator new(size_t size)
{
return mem_pool.allocate(size);
}
示例13: processAck
void TaggedPrefetcher::processAck(PAddr addr)
{
uint paddr = addr & defaultMask;
penFetchSet::iterator itF = pendingFetches.find(paddr);
if(itF == pendingFetches.end())
return;
bLine *l = buff->fillLine(paddr);
penReqMapper::iterator it = pendingRequests.find(paddr);
if(it != pendingRequests.end()) {
LOG("NLAP: returnAccess [%08lx]", paddr);
std::queue<MemRequest *> *tmpReqQueue;
tmpReqQueue = (*it).second;
while (tmpReqQueue->size()) {
tmpReqQueue->front()->goUpAbs(nextBuffSlot());
tmpReqQueue->pop();
}
pendingRequests.erase(paddr);
activeMemReqPool.in(tmpReqQueue);
}
pendingFetches.erase(paddr);
}
示例14: read
void MarkovPrefetcher::read(MemRequest *mreq)
{
uint32_t paddr = mreq->getPAddr() & defaultMask;
bLine *l = buff->readLine(paddr);
if(l) { //hit
LOG("GHBP: hit on [%08lx]", paddr);
hit.inc();
mreq->goUpAbs(nextBuffSlot());
return;
}
penFetchSet::iterator it = pendingFetches.find(paddr);
if(it != pendingFetches.end()) { // half-miss
//LOG("GHBP: half-miss on %08lx", paddr);
halfMiss.inc();
penReqMapper::iterator itR = pendingRequests.find(paddr);
if (itR == pendingRequests.end()) {
pendingRequests[paddr] = activeMemReqPool.out();
itR = pendingRequests.find(paddr);
}
I(itR != pendingRequests.end());
(*itR).second->push(mreq);
return;
}
//LOG("GHBP: miss on [%08lx]", paddr);
miss.inc();
mreq->goDown(0, lowerLevel[0]);
}
示例15: read
void AlwaysPrefetch::read(MemRequest *mreq)
{
uint32_t paddr = mreq->getPAddr() & defaultMask;
bLine *l = buff->readLine(paddr);
if(l) { //hit
LOG("NLAP: hit on [%08lx]", (long unsigned int) paddr);
hit.inc();
mreq->goUpAbs(nextBuffSlot());
return;
}
penFetchSet::iterator it = pendingFetches.find(paddr);
if(it != pendingFetches.end()) { // half-miss
LOG("NLAP: half-miss on %08lx",(long unsigned int) paddr);
penReqMapper::iterator itR = pendingRequests.find(paddr);
halfMiss.inc();
if (itR == pendingRequests.end()) {
pendingRequests[paddr] = activeMemReqPool.out();
itR = pendingRequests.find(paddr);
}
I(itR != pendingRequests.end());
(*itR).second->push(mreq);
//prefetch(paddr+lineSize, 0);
//prefetch( paddr + buff->getLineSize(), 0 );
return;
}
LOG("NLAP: miss on [%08lx]", (long unsigned int) paddr);
miss.inc();
Time_t lat = nextTableSlot() - globalClock;
prefetch(paddr+(buff->getLineSize()), lat);
lat = nextTableSlot() - globalClock;
prefetch(paddr+(2*buff->getLineSize()), lat);
mreq->goDown(0, lowerLevel[0]);
}