c - 链表删除并返回第一个元素

标签 c list loops linked-list element

我正在尝试使用 C 解析 shell 脚本中的命令。我当前已设置链接列表,但在正确删除和返回第一个元素时遇到问题。当我尝试获取第一个元素时,它一次工作正常,但之后它被卡住并进入无限循环,我不明白为什么。预先感谢您的任何帮助。这是我的代码:

     enum command_type
       {
         AND_COMMAND,         // A && B
         SEQUENCE_COMMAND,    // A ; B
         OR_COMMAND,          // A || B
         PIPE_COMMAND,        // A | B
         SIMPLE_COMMAND,      // a simple command
         SUBSHELL_COMMAND,    // ( A )
       };

     // Data associated with a command.
     struct command
     {
       enum command_type type;

       // Exit status, or -1 if not known (e.g., because it has not exited yet).
       int status;

       // I/O redirections, or null if none.
       char *input;
       char *output;

       union
       {
         // for AND_COMMAND, SEQUENCE_COMMAND, OR_COMMAND, PIPE_COMMAND:
                  struct command *command[2];

         // for SIMPLE_COMMAND:
         char **word;

         // for SUBSHELL_COMMAND:
         struct command *subshell_command;
       } u;
     };

     typedef struct command_stream *command_stream_t;
     typedef struct command *command_t;

     struct command_stream
     {
        command_t command_stream;
        command_stream_t next;
     }

     command_t
     read_command_stream(command_stream_t s)
     {
        if(s)
        {
           command_t comm = s->command;
           s=s->next;
           return comm;
        }
        return NULL;
     }

     void printList(command_stream_t head)
     { 
        command_t command;
        while((command = read_command_stream(head)))
        { 
           //print_command is a function that takes in a command_t and then prints the    
           //command in a nice format.
           print_command(head->command);
        }
     }

最佳答案

在此函数中,您正在修改指针的本地副本(不是您传入的主指针),因此您的head指针永远不会移动。

 command_t
 read_command_stream(command_stream_t s)
 {
    if(s)
    {
       command_t comm = s->command;
       s=s->next;
       return comm;
    }
    return NULL;
 }

您需要更改此函数以接受指针到指针,如果您不理解这个概念,我建议一本好书(或教程)将帮助您入门。

关于c - 链表删除并返回第一个元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14355123/

相关文章:

c - 多个文件中的静态函数

python - 获取用户输入并将其放入字符列表中(Python 3)

使用 fseek 计算文件字符数

c - Gcc 纯/常量函数和 longjmp

python - 如何最好地使用 Python 列表?

javascript - Angular2 在 ngFor 循环中绑定(bind)事件/DOM

javascript - 为什么 CoffeScript 不是 "reusing"循环变量?

C++ 为什么我的循环中断了?

c - OpenCV中的矩形矩阵计算

python - 从 Pandas Dataframe 中的列表中提取元组