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 + -
显示快捷键?