C - 初始化动态列表时出现问题

时间:2012-11-17 08:11:30

标签: c

我正在写一个二十一点程序中的交易功能有问题。任何人都可以看到发生了什么?当我尝试在main()中打印时,我遇到了分段错误。

干杯。

主要功能

int main(void)
{
    int i, j, k, purse;
    card deck[52];
    card *head_d, *temp_d, *current_d = NULL, *last_d, *head_p, *temp_p, *current_p = NULL, *last_p;



make(deck);  //CREATES THE DECK
shuffle(deck); //SHUFFLES THE DECK
deal(deck, head_d, current_d, head_p, current_p)

for(i = 0; i < DECK_SIZE; i++)
    {
        printf("%d: %d %c\n", i + 1, deck[i].face, deck[i].suit);
    }

temp_p = head_p;
while(temp_p != NULL)
{
printf("%d %c\n", temp_p->face, temp_p->suit);
temp_p = temp_p->listp;
}

return(0);
}

FUNCTION deal()

  void deal(card x[DECK_SIZE], card *head_d, card *current_d, card *head_p, card *current_p)
    {

    int i;
    card *temp_p, *temp_d;

    for(i = 0; i < 4; i++)
    {
        if( i % 2 == 0)
        {
            temp_p = (card *)malloc(sizeof(card));
            temp_p->face = x[i].face;
            temp_p->suit = x[i].suit;

            if (current_p==NULL)
            {
                head_p=temp_p;
            }
            else
            {
                current_p->listp=temp_p;
            }
                current_p = temp_p;
                temp_p->listp = NULL;

        }
        else
        {
            temp_d=(card *)malloc(sizeof(card));
            temp_d->face = x[i].face;
            temp_d->suit = x[i].suit;

            if (current_d==NULL)
            {
                head_d=temp_d;
            }
            else
            {
                current_d->listp=temp_d;
            }
                current_d = temp_d;
                temp_d->listp = NULL;
        }
    }
}

2 个答案:

答案 0 :(得分:2)

问题是deal函数的参数是 local ,这意味着当您在函数中更改它们的值时,调用函数时使用的变量将不会更改。您需要通过引用传递参数

void deal(card x[DECK_SIZE], card **head_d, card **current_d, card **head_p, card **current_p);

do do。

*head_p=temp_p;

在设置变量的函数中。

呼叫

deal(deck, &head_d, &current_d, &head_p, &current_p);

答案 1 :(得分:0)

您的head_p函数中有未初始化的指针变量main。然而,您正在尝试读取head_p所指向的数据。当然,你会得到段错误。