- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我重构了一个使用单个元素列表的类,因此它现在使用这样的列表的列表。为了尽量减少派生类的变化,我实现了一个自定义 iterator
使用 boost::iterator_facade
还有一种获取 boost::iterator_range<iterator>
的方法可用于迭代而不是原始列表。
除了在rbegin()
用来。 boost::iterator_range
似乎不支持类似的东西。
获取范围最后一个元素的简单方法是什么?
我使用的是 VS2008 SP1,即在 std::tr1 中只有一些 C++11 支持,并且显然也可以使用 boost。
typedef std::deque<MyData> DataList;
class MyClass : private boost::noncopyable
{
public:
void AppendData(DataList* newData
private:
typedef std::deque<DataList*> ListOfDatatLists;
/**
* Custom iterator.
* The content is not meant to be modified so this iterator operates on const lists only.
*/
class iterator
: public boost::iterator_facade <
iterator,
MyData,
boost::forward_traversal_tag // Only forward iteration necessary
>
{
public:
static boost::iterator_range<iterator> range(const ListOfDataLists * pListOfLists);
private:
friend class boost::iterator_core_access;
iterator(const ListOfDataLists * pListOfLists = NULL) : m_pListOfLists(pListOfLists) {}
/// \name Implementations for boost base class
//{@
bool equal(iterator const & other) const;
MyData & dereference() const;
void increment();
difference_type distance_to(const iterator & other) const;
//@}
const ListOfDataLists * m_pListOfLists;
ListOfDataLists::const_iterator m_listIt; ///< The current list of data items
DataList::const_iterator m_dataIt; ///< An iterator of the current list
};
ListOfResultLists m_dataLists;
protected:
typedef std::tr1::shared_ptr<CLockedResults> SpLockedResults;
/// For use by derived classes instead of the former single list
boost::iterator_range<iterator> GetData() const;
};
最佳答案
如果可能,一个解决方案是允许双向或随机访问遍历。这将允许您调用 range.end() --
(假设范围不为空)。这还允许您使用 reversed
boost 范围适配器来反转范围。
另一种解决方案是使用 begin()/end()
从范围中获取迭代器,并使用 std::distance
确定之间的距离两个迭代器。然后,您可以使用 std::advance
开始迭代器,该迭代器比移动到最后一个元素的距离小一个。
关于c++ - boost::iterator_range 的 rbegin(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11155322/
我在使用这段代码的 C++ 中遇到了一个奇怪的问题: mutex_type list_mutex; typedef list RQueue; RQueue rQueue; RQueue::rever
我正在尝试使用排序函数对字符串进行排序:这是一个字符串:索引从零开始 "effort" 我的目标是从索引 (1 到 4)[n=1,m=4] 中按降序排序,即生成一个字符串: "erofft" 我使用函
在下图中,我正在使用相同类型的迭代器,这意味着相同的operator ++实现,因此编译器如何知道应获取下一个值还是前一个值...? 最佳答案 首先,您的图片包含错误。如您所见here, vector
下面函数中rbegin()和rend()判断输入是否回文的具体作用是什么? bool palindromeCheck(string input) { if (input == string(i
我需要从容器的开头迭代到结尾之前的一个元素。我可以在循环中放置一个 if 条件来绕过最后一个元素,但我想知道是否可以像这样编写 for 循环: for (it = C.begin(); it != C
我重构了一个使用单个元素列表的类,因此它现在使用这样的列表的列表。为了尽量减少派生类的变化,我实现了一个自定义 iterator使用 boost::iterator_facade还有一种获取 boos
运行下面的代码,我希望看到测试 1 的第 4 个值的不同地址(与值 1 和 3 不同)。这表明 rend() 与 rbegin() 相同??我也不希望循环经历第二次迭代并出现段错误。 知道我做错了什么
为什么下面的代码会崩溃? int main(int argc, const char * argv[]) { std::list aList={1,2,3,4,5}; std::list::rever
我想知道使用 rbegin() 而不是 end() - 1 对 STL 容器有什么好处。 例如,你为什么要使用这样的东西: vector v; v.push_back(999); vector::re
我有一些名为 Order 的类。由于某些原因,以下代码在使用 rbegin() 时无法编译,但它适用于 begin()。我声明迭代器的方式有问题还是我的指针引用有问题? map> m typedef
既然在 C++11 修订版中为标准包含添加了非成员 begin() 和 end() 函数,为什么会有非成员版本的 rbegin() 和 rend() 函数也没有添加?开始使用begin()和end()
这个问题已经有答案了: How to call erase with a reverse iterator (14 个回答) 已关闭 3 年前。 社区去年审查了是否重新开放此问题,并将其关闭: 原始关
下面是我的 String 类的代码。我想实现 reverse_iterator 和 rbegin() 和 rend() 方法。已粘贴分配方法的代码。 String::reverse_iterator
我正在使用 boost::tokenizer,但我意识到它不支持 rbegin() 和 rend()。我想请问如何将这两个功能添加到现有类中? 这是来自 boost 网站: #include #in
根据我发现的一些 STL 文档,在 std::list 中插入或删除元素不会使迭代器无效。这意味着它可以遍历一个列表(从 begin() 到 end()),然后使用 push_front 添加元素。
对于 std::set 和 std::map 等以对数时间查找的数据类型,实现是否需要维护开始和结束迭代器?访问 begin 和 end 是否意味着查找可能以对数时间发生? 我一直假设开始和结束总是在
我遇到了一个特殊问题,我的团队担心使用 std::chrono。 我们正在使用 MSVS-13,所以是 C++11。 我有一组对象状态存储在多映射中,以 std:chrono::millisecond
我一直在 MSVC 2013 中使用 std::rbegin 和 std::rend。当我尝试使用 GCC 4.9.1 或 clang 3.5.0 编译我的代码时,两者都告诉我“rbegin”和“re
我是一名优秀的程序员,十分优秀!