我已经给出了一些用于实现链接列表的现有C代码(一个头文件和一些源代码),并且已经给了一个任务用它来实现一个队列。使用链接列表的现有实现来实现队列:错误的文件编号错误
这是我一直在考虑相关的功能描述中的头文件的一部分:
/* List is a pointer to a list_t struct */
typedef struct list_t* List;
struct list_t {
void *data;
List next;
};
/* Pushes data as the new head of list. May be used to create a new list:
* new_list = push(NULL, data) */
extern List push(List list, void *data);
/* Pop the head off the list */
extern void *pop(List *list);
/* Return the length of the list */
extern int len(List list);
/* Returns a reversed copy of list */
List reverse(List list);
/* Prepend data to list and update list */
extern List prepend(List *list, void *data);
/* Append l1 to the end of l2 */
void append(List l1, List *l2);
/* Inserts data into the tail of list */
void insert(void *data, List *list);
/* Inserts data into the tail of list or position equal to the next element */
void insert_by(bool (*eq)(void *data, void *node), void *data, List *list);
/* Inserts data into the tail of list. Returns true if sucessful,
* false if it finds an element already equal to data */
bool insert_if(bool (*eq)(void *data, void *node), void *data, List *list);
/* Returns the node equal to aim in list, returns NULL if not found */
extern List find(bool (*eq)(void *aim, void *node), void *aim, List list);
/* Removes and returns the element equal to aim in list,
* returns NULL if not found */
extern void *del(bool (*eq)(void *aim, void *node), void *aim, List *list);
/* Returns a new list that passes the predicate p */
List filter(bool (*p)(void *data), List list);
/* Print list to f by applying print to each node that is not NULL */
extern void print_list(void (*print)(FILE *f, void *data), FILE *f, List node);
/* Free the memory allocated to each list node */
extern void free_list(List node);
我知道,为了实现一个队列,我需要至少两个功能,enqueue()
和dequeue()
。我继续创建了这些功能和队列的类型定义我自己的头文件,使用列表类型从上面的头文件:
//Queue.h
#include "list.h"
typedef List Queue;
//Add item to queue...
void enqueue(Queue q, void *data);
//removes and returns an item from the queue...
void dequeue(Queue *q);
然后我继续在queue.c
实现的源代码。我只为实现enqueue
现在,因为我想确保它在移动之前的工作:
#include "queue.h"
void enqueue(Queue q, void *data){
if (q == NULL){
q = push(q, data);
}
else {
insert(data, &q);
}
}
真不简单,我知道了。我打算用下面的文件,main.c
所测试的队列:
#include <stdio.h>
#include "queue.h"
int main(int argc, char **argv){
Queue q = NULL;
int i;
for (i = 0; i < 10; i++){ enqueue(q, &i); } //one line for brevity
return 0;
}
在这一点上我不希望看到任何输出,当我跑main.c
,所有我的预期是该方案与没有错误运行然后停下来。一切编译正常,但是当我跑main.c
所有我得到的是:
sh: ./main.exe: bad file number
这是什么意思和任何人可以查明这可能是造成这个问题呢?
编辑:源代码被编译为这样:
gcc -c list.c
gcc -c queue.c
gcc -c main.c -o main.exe
请问你可以像这样编译 - > gcc list.c queue.c main.c -o main .exe –