C ++中嵌套模板类返回类型的头文件中函数返回类型的语法

时间:2019-01-19 03:28:50

标签: c++ vector data-structures inner-classes

我正在构建自己的向量类,类似于可以找到C ++ STL的向量。在我的头文件中有两个类,向量类和迭代器类,这是一个嵌套的模板类。我想知道嵌套迭代器类的返回类型的正确语法是什么。在这种情况下,我的代码将为我的begin()函数和end()函数编写正确的返回类型语法,这两种方法都在我的向量类中。 begin()end()都应该具有vector <T> :: iterator的返回类型,但这似乎不起作用。这是我当前代码的设置方式。

template <class T>
iterator;

/************************************************
 * VECTOR
 * A class that holds stuff
 ***********************************************/
template <class T>
class vector
{
public:
   // code removed for brevity

   // Methods of the Vector class
   vector <T> :: iterator begin();
   vector <T> :: iterator end();


private:
   // Code removed for brevity
};

/**************************************************
* VECTOR ITERATOR
* An iterator through array
*************************************************/
template <class T>
class vector <T> :: iterator
{
    // ...code removed for brevity
};

此外,我在.h文件顶部的以下两行是否具有正确的代码?

template <class T>
iterator;

还是这个?

template <class T>
vector <T> :: iterator;

谢谢!

1 个答案:

答案 0 :(得分:3)

您只需将iterator的定义移至vector中即可:

template <class T>
class vector {
public:
    class iterator {
        /* How you implement a iterator of type T */
    };

    iterator begin(); // for example

    // other fantastic stuff
};

template <class T>
vector<T>::iterator vector<T>::begin()
{
    // whatever
}

如果您不想在其中定义iterator,可以这样做:

template <class T>
class vector {
public:
    class iterator; // only a declaration

    iterator begin(); // same

    // other fantastic stuff
};

template <class T>
class vector<T>::iterator {
    // the actual definition goes here
};

template <class T>
vector<T>::iterator vector<T>::begin()
{
    // same
}

或者,您也可以分别定义iterator 并将vector::iterator设为别名:

template <class T>
class iterator { /* real definition */ };

template <class T>
class vector {
public:
    using iterator = ::iterator<T>;
    // or typedef ::iterator<T> iterator;

    iterator begin(); // still the same

    // same fantastic stuff
};

template <class T>
vector<T>::iterator vector<T>::begin()
{
    // all the same
}

希望这会有所帮助。