walk_tg_tree_from的图解

简介: walk_tg_tree_from的图解

在遍历task_group的时候,需要会调用到walk_tg_tree_from函数,从函数注释看,这个函数的流程是:

from为根节点,当进入一个节点时调用down回调函数,当离开一个节点时调用up函数。这个函数

采用的是深度遍历。

下面用一张图来说明:

/*
 * Iterate task_group tree rooted at *from, calling @down when first entering a
 * node and @up when leaving it for the final time.
 *
 * Caller must hold rcu_lock or sufficient equivalent.
 */
int walk_tg_tree_from(struct task_group *from,
           tg_visitor down, tg_visitor up, void *data)
{
  struct task_group *parent, *child;
  int ret;
  parent = from;
down:
  ret = (*down)(parent, data);
  if (ret)
    goto out;
  list_for_each_entry_rcu(child, &parent->children, siblings) {
    parent = child;
    goto down;
up:
    continue;
  }
  ret = (*up)(parent, data);
  if (ret || parent == from)
    goto out;
  child = parent;
  parent = parent->parent;
  if (parent)
    goto up;
out:
  return ret;
}
相关文章
|
8月前
|
缓存 索引
图解B Tree和B+ Tree
图解B Tree和B+ Tree
78 0
RB-tree(红黑树)详解
RB-tree(红黑树)详解
83 0
Leetcode 623. Add One Row to Tree
题目很简单,在树的第d层加一层,值为v。递归增加一层就好了。代码如下
55 0
LeetCode 429. N-ary Tree Level Order Traversal
给定一个 N 叉树,返回其节点值的层序遍历。 (即从左到右,逐层遍历)。
93 0
LeetCode 429. N-ary Tree Level Order Traversal
|
Python
[Leetcode][python]Unique Binary Search Trees/不同的二叉查找树
题目大意 给出一个n,求1-n能够得到的所有二叉搜索树
105 0
|
算法 JavaScript Java
并查集算法 - Algorithms, Part I, week 1 UNION-FIND
cousera 普林斯顿大学 算法公开课 第一周 并查集数据类型内容整理
1532 0