所以,从.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中以使其更具可读性。
原因是专用模板类的代码是在使用时生成的。如果你只想使用一些众所周知的模板类的专门化,你可以使用与头文件分离的实现,并强制创建这些专门化。
还有一些:为什么模板只能在头文件中实现?