单向链表如何实现一个迭代器函数
数据结构是这样的:
typedef struct node { void *data; struct node *next; } node_t; typedef struct list { node_t *head; } list_t;
其中node_t 结构是操作封装的.
我想实现一个迭代器函数
int list_iter(list_t *,void *);
当循环达到list结束的时候返回0,否则返回1
也就是我可以这么使用iter:
while(list_iter(list,&data)){ //do something,such as get out data }
我想封装这个函数, 要用到static .但是static修饰的迭代节点指针不能很好的指示链表结束
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
我认为两个方案
1,在list_iter中每读出一个node销毁一个,直到某个node->next为null
2,扩展list_t,增加一个node_t *c_node。默认同head,每读一个向下走一个,直到null
你可以试试。不知你是不是这个意思。