rbtree.h
来自「eCos操作系统源码」· C头文件 代码 · 共 47 行
H
47 行
#ifndef _LINUX_RBTREE_H#define _LINUX_RBTREE_Hstruct rb_node { struct rb_node *rb_left; /* left element */ struct rb_node *rb_right; /* right element */ struct rb_node *rb_parent; /* parent element */ int rb_color; /* node color */};struct rb_root { struct rb_node *rb_node; /* root of the tree */};#define NULL ((void *)0)#define RB_ROOT ((struct rb_root){NULL})#define rb_entry(p, container, field) \ ((container *) ((char *)p - ((char *)&(((container *)0)->field))))#define RB_BLACK 0#define RB_RED 1extern void rb_insert_color(struct rb_node *, struct rb_root *);extern void rb_erase(struct rb_node *, struct rb_root *);/* Find logical next and previous nodes in a tree */extern struct rb_node *rb_next(struct rb_node *);extern struct rb_node *rb_prev(struct rb_node *);extern struct rb_node *rb_first(struct rb_root *);/* Fast replacement of a single node without remove/rebalance/add/rebalance */extern void rb_replace_node(struct rb_node *victim, struct rb_node *new, struct rb_root *root);static inline void rb_link_node(struct rb_node * node, struct rb_node * parent, struct rb_node ** rb_link){ node->rb_parent = parent; node->rb_color = RB_RED; node->rb_left = node->rb_right = NULL; *rb_link = node;}#endif /* _LINUX_RBTREE_H */
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?