在带有模板的链表实现中无法解析的外部符号

unresolved external symbol in a linkedlist implementation with templates c++

本文关键字:符号 外部 实现 链表      更新时间:2023-10-16

所以,从.csv文件我正在创建用户,这是来自类User。我试图创建一个linkedlist,这将包含所有用户,但我得到一个错误插入到linkedlist,顺便说一下,被命名为"ListaLigada"。我一个人想不出来。

所以,这就是我得到的:

错误1错误LNK2019:未解析的外部符号"public: void "__thiscall ListaLigada::插入(类用户)"(?insert@?$ListaLigada@VUser@@@@QAEXVUser@@@Z)在函数中引用"void __cdecl genUserLList(类ListaLigada &)"(genUserLList@@YAXAAV ? ListaLigada@VUser@@@@@Z美元)C:UsersDanieldocumentsvisualstudio 2010ProjectsRadio StationRadio StationAuxf。obj广播站

如果你能指出我做错了什么,我会很感激,到现在已经漫长的2天了。

下面是相关的代码:

ListaLigada.h

    #pragma once
    #ifndef ListaLigada_H
    #define ListaLigada_H
    #include <cstddef>
    #include <cassert>
    template<class T>
    class ListaLigada
    {
    public:
        ListaLigada();
        ListaLigada(T elem);
        ~ListaLigada(void);
            void insert(T elem);
        void remElem(T elem);
        void remElem(int id_elem);
        void searchElem(int id_elem);
        void searchElem(T elem);
        void clear();
    private:
        struct Node{
            T data;
            Node *next;
            Node *prev;
        } *p;
        size_t list_size;
    };

    #endif

ListaLigada.cpp

    #include "ListaLigada.h"
    template<class T>
    ListaLigada<T>::ListaLigada()
    {
        list_size=0;
        this->p=new Node;
        this->p=NULL;
    }
    template<class T>
    ListaLigada<T>::~ListaLigada(void)
    {
        clear();
    }
    template<class T>
    ListaLigada<T>::ListaLigada(T elem)
    {
        node *q, *t;
        if(p == NULL)
        {
            p=new Node;
            p->data= elem;
            p->next= Null;
            list_size++;
        }
        else
        {
            q=p;
            while(q->next!= NULL)
                q= q->next;
            t= new node;
            t->data= elem;
            t->next=Null;
            t->prev=q;
            q->next=t;
            list_size++;
        }
    }
    template <class T>
    void ListaLigada<T>::insert(T elem)
    {
        node *q, *t;
        if(p == NULL)
        {
            p=new Node;
            p->data= elem;
            p->next= NULL;
            list_size++;
        }
        else
        {
            q=p;
            while(q->next!= NULL)
                q= q->next;
            t= new node;
            t->data= elem;
            t->next=NULL;
            t->prev=q;
            q->next=t;
            list_size++;
        }
    }
    template <class T>
    void ListaLigada<T>::remElem(T elem)
    {
        node *q, *t;
        if(p== NULL)
        {
            system("cls");
            cout<<"There's nothing to removen";
            _getch();   
        }
        else
        {
            q=p;
            while(q->next != NULL){
                //e se for o unico elemento?
                if(list_size==1)
                {
                    ~ListaLigada();
                //blahblah limpar ficheiros
                    break;
                }
                else
                {
                    if(q->data.getId() == )
                }
            }
        }
    }
    template <class T>
    void ListaLigada<T>::remElem(int id_elem){}
    template <class T>
    void ListaLigada<T>::searchElem(int id_elem){}
    template <class T>
    void ListaLigada<T>::searchElem(T elem){}
    // deletes all the list elements
    template <class T>
    void ListaLigada<T>::clear()
    {
    node *q;
    if( p == NULL )
    return;
    while( p != NULL )
    {
    q = p->next;
    delete p;
    p = q;
    listSize--;
    }
    //assert(listSize==0);
    }

auxf.h

#ifndef AUX_H
#define AUX_H
//#include "includes.h"
#include "ListaLigada.h"
#include "Music.h"
#include "User.h"
#include "RadioStation.h"
#include <conio.h>
#include <string>
#include <iostream>
#include <fstream>
#include <sstream>
#include <iomanip>
#include <list>
#define MIN_LEN 2
bool strMinLen(string str, int min_len);
void fillField(string &to_fill, const string &what_is);
void checkFiles();
void loadInfo(vector<int> &vec); //carrega ids maximos
void regUser();
void addMusic();
void updateRestoreTxt(const int &line);
void loadRestore();
void updateRestore();
//void genUserLList(list<User> &lista);
void genUserLList(ListaLigada<User>);

#endif

auxf.cpp//我将只发布与

相关的函数
void genUserLList(ListaLigada<User> &lista){
    ifstream ifs;
    ifs.open("users.csv");
    if(ifs){
        int to_read;
        to_read=getNUsers(); //nr of users to read

        string user_line;
        getline(ifs, user_line, ','); //linha cabecalho
        for(int i=0; i<to_read; i++){
            user_line.clear();
            string name, password;
            int age;
            char gender;
            unsigned int id=0;
            getline(ifs, user_line);
            stringstream sstream;
            sstream<<user_line;
            string tmp;
            stringstream sstmp;
            char delim= ',';
            getline(sstream, tmp, delim);
            sstmp<<tmp;
            sstmp>>id;
            sstmp.clear();
            tmp.clear();
            getline(sstream, name, ',');
            getline(sstream, tmp, ',');
            sstmp<<tmp;
            sstmp>>age;
            sstmp.clear();
            tmp.clear();
            getline(sstream, tmp, ',');
            sstmp<<tmp;
            sstmp>>gender;
            sstmp.clear();
            tmp.clear();
            getline(sstream, password, ',');
            User n_user(id, name, age, gender, password);
            /*list<User>::iterator it;
            it=lista.end();
*/
            lista.insert(n_user);
        }
    }
    else{
        cout<<"Lista Ligada ta fddn";
        _getch();
    }
}

提前感谢。我不知道该怎么办了……我正在读取用户

当您使用模板化的类时,您需要完整的定义,这也包括了所有的方法。因此,你不能把一个模板化的类分成头文件和源文件,所有的东西都必须在头文件中。

如果你想使用模板类,你不能在其他编译单元中实现它。

您应该在header中完成这些操作,或者将此实现包含在您的header中以使其更具可读性。

原因是专用模板类的代码是在使用时生成的。如果你只想使用一些众所周知的模板类的专门化,你可以使用与头文件分离的实现,并强制创建这些专门化。

还有一些:为什么模板只能在头文件中实现?

相关文章: