如果InputReader
在头文件中声明为一个恒定大小的数组,那么它应该与您#include <array>
或#include <iterator>
其他几个库头中的任何一个一样工作,以便您获得声明
template<typename T, std::size_t N> T* std::begin(T (&array)[N]);
template<typename T, std::size_t N> T* std::end(T (&array)[N]);
但是如果InputReader
声明类似
extern InputReaderObject* InputReader;
或许
extern InputReaderObject InputReader[];
...?从数组中有多少对象并不明显,但我们假设同一个标题也有类似的东西:
extern unsigned int InputReaderSize;
您传递到基于范围的 for 循环中的任何内容都需要具有返回迭代器的函数begin
。end
(函数可以是类成员,通过依赖于参数的查找找到,或者在namespace std
.)标准库为实际数组和标准容器定义了一些begin
和end
函数,但您可以通过定义自己的来扩展它:
#include <iterator>
struct InputReaderLoopType {
InputReaderObject* begin() const { return InputReader; }
InputReaderObject* end() const { return InputReader + InputReaderSize; }
};
extern const InputReaderLoopType InputReaderLoop;
会让你做...
for ( InputReaderObject& irb : InputReaderLoop )
(irb
提供参考而不是副本只是一个建议。出于某种原因,您实际上可能需要副本。)
您还可以定义InputReaderObject* begin(InputReaderObject*);
并且InputReaderObject* end(InputReaderObject*);
如果您真的希望循环InputReader
像已经声明的那样使用。但是,如果有人有一个实际上不是那种类型的指针,那可能会导致令人困惑的结果InputReader
。