我有这样的结构:
typedef struct kodProgramu {
char* etykieta;
char* instrukcja;
char* operand;
struct kodProgramu *nast;
} kodPrg;
此代码用于添加新元素:
void pobierzKodStdin(kodPrg *kod, char *wynik, char *linia, int flagaEtyk)
{
wynik = fgets(linia, 80, stdin);
while(wynik != NULL)
{
kodPrg *wsk, *nowy;
wsk = kod;
while(wsk->nast != NULL)
wsk = wsk->nast;
if(linia[0] == ' ')
flagaEtyk = 1;
nowy = (kodPrg*)malloc(sizeof(kodPrg));
int licznik = 0;
char *pch;
pch = strtok(linia, ":# ");
while(pch != NULL)
{
if(flagaEtyk == 0)
{
if(licznik == 0)
nowy->etykieta = pch;
else if(licznik == 1)
nowy->instrukcja = pch;
else if(licznik == 2)
nowy->operand = pch;
}
if(flagaEtyk == 1)
{
if(licznik == 0)
nowy->instrukcja = pch;
else if(licznik == 1)
nowy->operand = pch;
}
licznik++;
pch = strtok(NULL, ":# ");
}
nowy->nast = NULL;
wsk->nast = nowy;
flagaEtyk = 0;
wynik = fgets(linia, 80, stdin);
}
}
此功能将此结构打印到控制台:
void wypiszKod(kodPrg *kod)
{
kodPrg *wsk = kod;
while(wsk != NULL)
{
printf("%s %s %s\n", wsk->etykieta, wsk->instrukcja, wsk->operand);
wsk = wsk->nast;
}
}
这是我的主要功能:
int main()
{
char linia[80], *wynik;
char *wsk = malloc(sizeof(char));
int flagaEtyk = 0;
//tasmaWejsc *wejscie = (tasmaWejsc*)malloc(sizeof(tasmaWejsc));
//tasmaWyjsc *wyjscie = (tasmaWyjsc*)malloc(sizeof(tasmaWyjsc));
//wyjscie->wartosc = 0;
//wyjscie->nast = NULL;
kodPrg *kod = (kodPrg*)malloc(sizeof(kodPrg));
kod->etykieta = " ";
kod->instrukcja = " ";
kod->operand = " ";
kod->nast = NULL;
int liczba;
//wprowadzWejscie(wynik, linia, wejscie);
//wypiszWejscie(wejscie);
//system("cls");
pobierzKodStdin(kod, wynik, linia, flagaEtyk);
wypiszKod(kod);
return 0;
}
现在,当我输入一行时:test test test 它在控制台中运行良好且打印测试测试。
但是当我输入更多行时,例如:
test test test
xxxx xxxx xxxx
该程序正在打印:
xxxx xxxx xxxx
xxxx xxxx xxxx
就像第二行取代第一行一样。 我不知道为什么,当我有一个带有int而不是char *的结构时,它运行良好。添加了下一个元素并且打印效果很好,但是当char *它正如我上面描述的那样工作时。
当我使用char *?
的struct时,如何将新elemnt添加到列表中答案 0 :(得分:0)
我认为你应该意识到strtok适用于静态缓冲区
所以当你这样写的时候
pch = strtok(linia, ":# ");
while(pch != NULL)
{
if(flagaEtyk == 0)
{
if(licznik == 0)
nowy->etykieta = pch;
您将闪亮堆元素中的指针指定给将在下一行(linia)消失的字符串。
wynik = fgets(linia, 80, stdin);
你需要做的是复制字符串,这可以使用strdup()
完成 nowy->etykieta = strdup(pch);
答案 1 :(得分:0)
链接列表中的每个字符串都映射到linia[80]
的部分,在每次访问时都会被覆盖。
一些strdup()
来电应解决您的问题。