“未定义的引用"到从静态方法访问的模板类的静态成员 [英] "undefined reference" to static member of template class accessed from static method

查看:45
本文介绍了“未定义的引用"到从静态方法访问的模板类的静态成员的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有一个静态类方法,需要访问指针 MyTypePointer,因此必须将其声明为静态.由于它是一个模板类,我必须将方法放在头文件中,但我无法在头文件中定义 MyTypePointer.

I have a static class method that needs access to a pointer MyTypePointer that therefore has to be declared static. Since it is a template class I have to put the methods inside the header file but I can't define MyTypePointer in the header.

因此我收到 "undefined Reference" 错误,因为 MyTypePointer 未声明.我怎样才能使这项工作/声明 MyTypePointer.

So I get the "undefined Reference" error since MyTypePointer is not declared. How can I make this work / declare MyTypePointer.

myclass.h

template <typename A, typename B>
class PathfindingClass {
    typedef std::vector<GenericEdgeClass<A, B>*> MyType;
    static MyType *MyTypePointer;
};

template <typename A, B>
void MyClass<A, B>::MyMethod(int x, int y) { 
    //do something with MyTypePointer
}

非常感谢.

推荐答案

这是一个迟到的完整参考答案,因为这个问题被链接为另一个问题的参考.

It is a late answer for full reference, as this question is linked as a reference to another question.

静态字段声明但未定义的最小损坏示例可能是:

A minimal broken example of a static field declared but not defined could be :

template<typename T>
class A
{
public:
    static T val;
    static void init()
    {
        val=0;
    }
};

int main()
{
    // A::init();
    A<double>::init();
    return 0;
}

修复只是在类定义之后定义静态字段:

The fix is just to define the static field after the class definition :

template<typename T>
class A
{
public:
    static T val;
    static void init()
    {
        val=0;
    }
};

template<typename T> T A<T>::val; // only change here

int main()
{
    // A::init();
    A<double>::init();
    return 0;
}

这篇关于“未定义的引用"到从静态方法访问的模板类的静态成员的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆