0

您好我正在尝试为模板构建空函数,以便稍后填写详细信息。这是我的代码:

namespace my {
    template <class T>
    class Sptr {
    private:
        //some kind of pointer
            //one to current obj
        T obj;
        size_t reference_count;
            //one to original obj
    public:
        template <typename U> Sptr(U *);
        Sptr(const Sptr &);
        //template <typename U> Sptr(const Sptr<U> &);
        ~Sptr();
        T* operator->() {return &obj;};
        template <typename U> Sptr<T> &operator=(const Sptr<U> &);
        //overload *,->,=,copy-constructor

        // const-ness should be preserved.
        // Test for null using safe-bool idiom
        // Static casting, returns a smart pointer
    };


    template <typename U> Sptr<U>::Sptr(U* u) {
        //do something
    }

    template <typename T> Sptr<T>::Sptr(const Sptr<T> &copyObj) {
        //do copy constructor stuff
    }

    template <typename T> Sptr<T>::Sptr& operator=(const Sptr<T> &T) {
        return *this;
    }
}

但是当我编译它时出现以下错误。

Sptr.hpp:30:24: error: prototype for ‘my::Sptr<T>::Sptr(U*)’ does not match any in class ‘my::Sptr<T>’
Sptr.hpp:17:3: error: candidates are: my::Sptr<T>::Sptr(const my::Sptr<T>&)
Sptr.hpp:16:25: error:                 template<class T> template<class U> my::Sptr::Sptr(U*)
Sptr.hpp:38:24: error: ‘my::Sptr<T>::Sptr’ names the constructor, not the type

我该如何解决?

4

3 回答 3

3
template <typename U> Sptr<U>::Sptr(U* u) {
    //do something
}

应该

template <typename T> 
   template <typename U>
       Sptr<T>::Sptr(U* u) {
        //do something
    }

其他成员函数模板类似。

于 2013-03-29T22:56:19.497 回答
2

您定义类模板的成员函数的方式不正确。以下是您应该如何定义构造函数模板:

template<typename T> // <== template parameter declaration for Sprt<T>
template<typename U> // <== template parameter declaration for constructor
Sptr<T>::Sptr(U* u) {
    //do something
}

这里是你应该如何定义operator =

template <typename T> // <== template parameter declaration for Sprt<T>
template<typename U> // <== template parameter declaration for operator
Sptr<T>& Sptr<T>::operator=(const Sptr<U> &t) {
    return *this;
}
于 2013-03-29T22:57:47.313 回答
1

您将构造函数和模板函数都定义operator=为模板函数。我不确定你真的想要那个。他们不应该只是T作为论据吗?你确定你不想在你的构造函数声明中使用这个:

Sptr(T*);

如果您确实希望它们成为函数模板,那么这是不正确的:

template <typename U> Sptr<U>::Sptr(U* u) {
    //do something
}

When you have a function template inside a function class, you need to give both sets of template arguments:

template <typename T>
template <typename U>
Sptr<T>::Sptr(U* u) {
    //do something
}
于 2013-03-29T22:57:50.430 回答