当前位置: 首页>>代码示例>>C++>>正文


C++ BlockList::erase方法代码示例

本文整理汇总了C++中BlockList::erase方法的典型用法代码示例。如果您正苦于以下问题:C++ BlockList::erase方法的具体用法?C++ BlockList::erase怎么用?C++ BlockList::erase使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在BlockList的用法示例。


在下文中一共展示了BlockList::erase方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: optimize

/** Perform simple tests to remove redundant blocks. */
void optimize(BlockList & blocks)
{
    int changes = 1;
    while (changes > 0)
    {
        changes = 0;
        BlockIter it = blocks.begin();
        while (it != blocks.end())
        {
            // Negative start indicates block is unreachable.
            if ((*it)->start < 0)
            {
                it = blocks.erase(it);
                ++changes;
            }

            // A block can be removed if it has no statements
            // and does not change locking status.
            else if ((*it)->stmts.size() == 0 && !(*it)->unlock)
            {
                int start = (*it)->start;

                //            cerr << "\nRemoving " << start << endl;

                Node closure = (*it)->closure;
                int transfer = (*it)->transfer;
                for (BlockIter ib = blocks.begin(); ib != blocks.end(); ++ib)
                {
                    if ((*ib)->start == transfer && closure !=0)
                        (*ib)->closure = closure;
                    if ((*ib)->transfer == start)
                        (*ib)->transfer = transfer;
                    if ((*ib)->altTransfer == start)
                        (*ib)->altTransfer = transfer;
                }
                it = blocks.erase(it);
                ++changes;
            }
            else
                ++it;
        }

        // Build a set of all labels in use
        set<int> labels;
        for (BlockIter it = blocks.begin(); it != blocks.end(); ++it)
        {
            labels.insert((*it)->transfer);
            labels.insert((*it)->altTransfer);

            // Include addresses of option nodes
            for (ListIter is = (*it)->stmts.begin(); is != (*it)->stmts.end(); ++is)
            {
                NodeKind k = (*is)->kind();
                if (k == OPTION_NODE || k == RECEIVE_OPTION_NODE || k == SEND_OPTION_NODE)
                    labels.insert((*it)->start);
            }
        }

        //      cerr << "Labels: ";
        //      for (set<int>::iterator it = labels.begin(); it != labels.end(); ++it)
        //         cerr << ' ' << *it;
        //      cerr << endl;

        it = blocks.begin();
        while (it != blocks.end())
        {
            if ((*it)->closure == 0 && labels.find((*it)->start) == labels.end())
            {
                it = blocks.erase(it);
                ++changes;
            }
            else
                ++it;
        }
    }
}
开发者ID:avallee,项目名称:Erasmus-LLVM,代码行数:77,代码来源:basicblocks.cpp


注:本文中的BlockList::erase方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。