0

テンプレートの C++ スタックを作成しようとしていますが、リンカーに問題があります。すべてのクラスを1つのcppファイルに入れようとしましたが、問題なく動作しますが、クラスを別のファイルに分けると問題が始まります

メインクラス:

#include <iostream>
#include "stack.h"

using namespace std;

int main()
{
    Stack<double>* st = new Stack<double>();
    st->push(new Data<double>(10));

    cout << st->pop()->getData();

    return 0;
}

stack.h :

#ifndef STACK_H
#define STACK_H

#include "data.h"

template <class T>
class Stack
{
public:
    Stack():_current(NULL){}
    void push(Data<T>* const);
    Data<T>* pop(); 

private:
    Data<T>* _current;
};

#endif;

スタック.cpp:

#include "stack.h"

template <class T>
Data<T>* Stack<T>::pop()
{
    if(this->_current == NULL)
    {
        cout << "Empty stack." <<endl;
        return NULL;
    }
    else
    {
        Data<T>* tmpPtr = this->_current;
        this->_current = this->_current->getPrev();
        return tmpPtr;
    }
}

template <class T>
void Stack<T>::push(Data<T>* const data)
{
    if(this->_current == NULL) // Empty stack;
    {
        _current = data;
        _current->setPrv(NULL);
    }
    else
    {
        Data<T>* tmpPtr = this->_current;
        this->_current = data;
        this->_current->setPrv(tmpPtr);
    }
}

data.h

#ifndef DATA_H
#define DATA_H

template <class T>
class Data
{
public:
    Data(T data):_data(data){}
    T getData() const { return this->_data; }
    void setPrv(Data* const prev){ this->_prev = prev; }
    Data* getPrev() const { return this->_prev; }
private:
    Data<T>* _prev;
    T _data;
};

#endif
4

2 に答える 2

1

テンプレート クラス関数のすべての定義を .h に入れます。基本的に別々のファイルにすることはできません。

これは、テンプレートが典型的なクラスとは異なるために発生します。コンパイラは、テンプレートのインスタンス化からクラスを生成します。このため、コンパイラは関数定義を検索する場所を知る必要があるため、クラスが定義されている .h 内に配置します。

于 2013-08-22T18:47:19.760 に答える
1

テンプレート関数は、特殊化 (使用) されるまでコンパイルされず、stack.cpp はマシン コードを生成しません。それらをstack.hに移動します

于 2013-08-22T18:50:25.497 に答える