- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在 C# 中,我可以执行以下操作
class MyClass {
private List<int> lst;
public IEnumerable<int> Numbers { get { return lst; } }
}
这具有让公众只读访问 lst
的效果,而不会将 List
成员变量暴露给公众。例如,类的用户可以写
foreach (var n in myClass.Numbers) { /* do something with the values * / };
但他们不能更改列表或以相反的顺序遍历它。这使我有可能稍后更改实现,而无需使用该类破坏代码。
我想用 C++ 做一些类似的事情:
class MyClass {
std::vector<int> lst;
public:
/* ???? */ getNumbers () const { return /* ??? */ lst; }
};
// I want to be able to write the following
auto rng = myClass.getNumbers ();
auto b = begin (rng);
auto e = end (rng);
// now b and e should be readonly (!) forward (!) iterators
我不关心编译时依赖性,即我不想使用 any_range
。但我这样做想在我的代码中明确表示我只保证只读转发行为。
最佳答案
你可以派生一个迭代器类型
template <typename Base>
struct const_forward_iterator : public Base {
using base_type = Base;
using iterator_type = const_forward_iterator;
using iterator_category = std::forward_iterator_tag;
const_forward_iterator& operator+=(typename Base::difference_type) = delete;
const_forward_iterator& operator-=(typename Base::difference_type) = delete;
const_forward_iterator operator+ (typename Base::difference_type) = delete;
const_forward_iterator operator- (typename Base::difference_type) = delete;
const_forward_iterator(base_type it) : base_type(it) {}
};
并以此为基础建立一个简单的范围
template <typename it>
struct range : std::pair<it,it> {
range(it b, it e) : std::pair<it,it>(b,e) {}
it begin() const { return this->first; }
it end() const { return this->second; }
};
利润:
using iterator_type = const_forward_iterator<std::vector<int>::const_iterator>;
range<iterator_type> getNumbers() const { return { lst.cbegin(), lst.cend() }; }
#include <vector>
#include <iterator>
namespace detail {
template <typename Base>
struct const_forward_iterator : public Base {
using base_type = Base;
using iterator_type = const_forward_iterator;
using iterator_category = std::forward_iterator_tag;
const_forward_iterator& operator+=(typename Base::difference_type) = delete;
const_forward_iterator& operator-=(typename Base::difference_type) = delete;
const_forward_iterator operator+ (typename Base::difference_type) = delete;
const_forward_iterator operator- (typename Base::difference_type) = delete;
const_forward_iterator(base_type it) : base_type(it) {}
};
template <typename it>
struct range : std::pair<it,it> {
range(it b, it e) : std::pair<it,it>(b,e) {}
it begin() const { return this->first; }
it end() const { return this->second; }
};
}
class MyClass {
std::vector<int> lst { 1, 3, 77, 42 };
public:
using iterator_type = detail::const_forward_iterator<std::vector<int>::const_iterator>;
detail::range<iterator_type> getNumbers() const { return { lst.cbegin(), lst.cend() }; }
};
#include <iostream>
int main()
{
MyClass o;
for (auto i : o.getNumbers())
std::cout << i << " ";
auto numbers = o.getNumbers();
//numbers.first += 2; error: use of deleted function
}
输出
1 3 77 42
当然,您可以分解代码以便重用位,但这是作为一个独立的 PoC
关于c++ - boost 模拟 C# 的 IEnumerable 的方式?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27713503/
任何人都可以向我解释 IEnumerable 和 IEnumerator 之间的区别是什么, 以及如何使用它们? 谢谢!!! 最佳答案 通常,一个 IEnumerable是可以枚举的对象,例如列表或数
function TSomething.Concat(const E: IEnumerable>): IEnumerable; begin Result := TConcatIterator.Cr
我正试图找到解决这个问题的办法: 给定一个 IEnumerable> 我需要一个返回输入的方法/算法,但是如果多个 IEnumerable 具有相同的元素,则每个巧合/组只返回一个。 例如 I
我有一个有趣的问题:给定一个 IEnumerable , 是否有可能产生 IEnumerable> 的序列一次将相同的相邻字符串分组? 让我解释一下。 1。基本说明示例: 考虑以下 IEnumerab
我有课 public class Test { public void M1(IEnumerable> p) { } public void M2(IEnumerable)> p) {
我尝试解决下一个练习: 输入:整数列表 count >= 1;一些正整数 k 输出:此整数的所有可能元组,长度为 k ; 例如 输入: {1, 2}; k = 4 输出: { {1, 1, 1, 1
抱歉奇怪的标题。我想要实现的目标很简单: IEnumerable> listoflist; IEnumerable combined = listoflist.CombineStuff(); 例子:
公共(public)类项目 { ... public class Order { public List Items ... } public class Customer {
我有一个 IEnumerable>我想转换为单一维度集合的集合。是否可以使用通用扩展方法来实现这一点?现在我正在这样做以实现它。 List filteredCombinations = new Lis
我有一个 IEnumerable> CustomObject在哪里有一个 x (用作键(在本例中为 1 、 2 、 3 ))和 y值(value)。一些假数据: { { {1, 2}, {2, 4
我需要做的是选择嵌套元素列表,这是我的查询 returns IEnumerable>这是我的 linq 表达式: from a in (questions.Select(x => x.AnswerLi
如何使用 LINQ(或其他方式)将 IEnumerables 的 IEnumerable 拆分为一个平面 IEnumerable? 最佳答案 enumerable.SelectMany(x => x)
例如: public interface IEnumerable { IEnumerator GetEnumerator(); } //This interface allows the c
我对 Reflection.Emit 有疑问。我想要动态创建的类,它具有 ICollection 的简单实现。我定义的所有方法都很好,而不是接下来的两个: public IEnumerator Get
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: Why was IEnumerable made covariant in C# 4? 我正在查看 MSDN
IEnumerator.MoveNext() 的实现是否预计会相对较快?或者如果“移动到下一项” 包括磁盘 IO、Web 请求或其他可能长时间运行的操作是否可以? 例如,我正在处理一个处理文档的项目,
以下代码创建了 List 的中间实例并在 yield 返回之前将值附加到它。有没有一种好的方法可以避免创建实例并直接 yield 返回单元格值? IEnumerable> GetStrValues()
我有两个 IEnumerable 对象,我想验证其中一个是否包含另一个的所有元素。 我正在使用 obj1.Intersect(obj2).Any() 但交集没有像我预期的那样工作。即使 obj2 中只
我正在尝试这个 MSDN page 上的例子.我试图更改 GetEnumerator 方法。我知道那似乎有些不对劲,但它符合要求然后就不会运行。错误是枚举器尚未启动,应该调用 MoveNext,但 它
我写过关于自定义 IEnumerator 的文章。从中生成 IEnumerable 的最简单方法是什么?理想的解决方案(一行代码)是是否有一些用于该目的的类。还是我必须自己创建? 最佳答案 不幸的是,
我是一名优秀的程序员,十分优秀!