这个函数应该从文件中加载一些个人信息并将其放入链表中,然后返回一个指针tp列表的第一个元素。使用的结构如代码,每个用户的全名和ID(索引)
typedef struct Serveur
{
char ID[6];
char nom[CMAX];
char prenom[CMAX];
struct Serveur *nxt;
}Serveur;
Serveur *creer_liste()
{
return NULL;
}
Serveur* add_server(Serveur *tete,char ID[6],char nom[CMAX],char prenom[CMAX])
{
Serveur* T=malloc(sizeof(Serveur));
T->ID=ID;
T->nom=nom;
T->prenom=prenom;
T->nxt=tete;
tete=T;
return tete;
}
Serveur *load_servers() //load servers list from the daba base and organise them
{
int c=0; char ID[6],nom[CMAX],prenom[CMAX];
Serveur *tete;
FILE *fichier=NULL;
fichier=fopen("base/serveurs_liste.txt","w");
if(fichier==NULL)
return NULL;
else
{
rewind(fichier);
c=fgetc(fichier);
if(c==EOF)
return NULL;
else
{
rewind(fichier);
while(!feof(fichier))
{
do{c=fgetc(fichier);}
while(c!='n');
fscanf(fichier,"%s %s %s",ID,nom,prenom);
tete=add_server(tete,ID,nom,prenom)
}
}
}
return tete;
}
但是我面临这个错误,在我看来每件事都是逻辑,我真的找不到那里出了什么问题,所以如果有人能弄清楚那里出了什么问题,请
您从 add_server
返回了错误的值。您应该返回新分配的T
:
Serveur* add_server(Serveur *tete,char ID[6],char nom[CMAX],char prenom[CMAX])
{
Serveur* T=malloc(sizeof(Serveur));
T->ID=ID;
T->nom=nom;
T->prenom=prenom;
T->nxt=tete;
return T;
}