最近在指导学生开发VxWorks下的程序,其中要使用双向链表lstLib,由于所参考的VxWorks的书中没有给出例子。写了下面这个简单的例子。
#include <stdlib.h>
#include <stdio.h>
#include <lstLib.h>
typedef struct _Queue

{
NODE * next;
NODE * prev;
int age;
char name[255];
} QUEUE;
LIST list;
void TestList()

{
QUEUE *p;
int i;
lstLibInit();
lstInit(&list);
for(i = 0; i < 10; i++)
{
p = malloc(sizeof(QUEUE));
if(p) 
{
p->age = i * 5;
sprintf(p->name, "person %d", i);
lstAdd(&list, (NODE*)p);
}
}
for(i = 0; i < 10; i++)
{
p = (QUEUE*)lstGet(&list);
if(p)
{
printf("name = %s, age = %d\n", p->name, p->age);
free(p);
}
}
lstFree(&list);
}
本文提供了一个在VxWorks环境下使用lstLib库实现双向链表的简单示例程序,通过创建、添加和遍历节点来演示基本操作。
9100

被折叠的 条评论
为什么被折叠?



