我希望有一个基于范围的自定义循环,但没有副本构造函数。似乎在某个时候有副本,但我不明白为什么。
这是我要运行的示例:http://cpp.sh/63pa6
class Range
{
public:
Range( int begin, int end )
: iter_( begin ),
last_( end )
{
}
Range(Range&&) = default;
Range& operator=(Range&&) = default;
Range(const Range&) = delete;
bool operator!=( const Range & /*unused*/ ) const
{
return iter_ != last_;
}
void operator++()
{
++iter_;
}
const Range &begin() const
{
return *this;
}
const Range &end() const
{
return *this;
}
int operator*() const
{
return iter_;
}
private:
int iter_;
int last_;
};
此代码无法编译:
int main()
{
for( auto i : Range( 2, 8 ) )
{
std::cout << i << std::endl;
}
}
编译错误:error: use of deleted function 'Range::Range(const Range&)'
答案 0 :(得分:3)
基于范围produces the following code的范围:
{
auto && __range = range_expression ;
for (auto __begin = begin_expr, __end = end_expr;
__begin != __end; ++__begin) {
range_declaration = *__begin;
loop_statement
}
}
如您所见,这将创建两个副本__begin
和__end
。
答案 1 :(得分:0)
我认为定义迭代器包装器会更简单:
struct range : std::pair<int,int> {
struct int_iter {
int_iter( int i ) : i(i) {}
int operator*() { return i; }
int &operator++() { return ++i; }
bool operator!=( int_iter end ) const { return i != end.i; }
private:
int i;
};
using std::pair<int,int>::pair;
int_iter begin() const { return int_iter( first ); }
int_iter end() const { return int_iter(second); }
};