WangHan
2024-09-12 d5855a4926926698b740bc6c7ba489de47adb68b
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
package tech.powerjob.server.core.workflow.algorithm;
 
import com.google.common.collect.Lists;
import com.google.common.collect.Maps;
import lombok.*;
import tech.powerjob.common.model.PEWorkflowDAG;
 
import java.util.List;
import java.util.Map;
 
/**
 * DAG 工作流对象
 * 节点中均记录了上游以及下游的连接关系(无法使用 JSON 来序列化以及反序列化)
 *
 * @author tjq
 * @author Echo009
 * @since 2020/5/26
 */
@Data
@ToString(exclude = {"nodeMap"})
@NoArgsConstructor
@AllArgsConstructor
public class WorkflowDAG {
 
    /**
     * DAG允许存在多个顶点
     */
    private List<Node> roots;
 
    private Map<Long, Node> nodeMap;
 
    public Node getNode(Long nodeId) {
        if (nodeMap == null) {
            return null;
        }
        return nodeMap.get(nodeId);
    }
 
    @Getter
    @Setter
    @EqualsAndHashCode(exclude = {"dependencies", "dependenceEdgeMap", "successorEdgeMap", "holder","successors"})
    @ToString(exclude = {"dependencies", "dependenceEdgeMap", "successorEdgeMap", "holder"})
    @NoArgsConstructor
    public static final class Node {
 
        public Node(PEWorkflowDAG.Node node) {
            this.nodeId = node.getNodeId();
            this.holder = node;
            this.dependencies = Lists.newLinkedList();
            this.dependenceEdgeMap = Maps.newHashMap();
            this.successors = Lists.newLinkedList();
            this.successorEdgeMap = Maps.newHashMap();
        }
 
        /**
         * node id
         *
         * @since 20210128
         */
        private Long nodeId;
 
        private PEWorkflowDAG.Node holder;
        /**
         * 依赖的上游节点
         */
        private List<Node> dependencies;
        /**
         * 连接依赖节点的边
         */
        private Map<Node, PEWorkflowDAG.Edge> dependenceEdgeMap;
        /**
         * 后继者,子节点
         */
        private List<Node> successors;
        /**
         * 连接后继节点的边
         */
        private Map<Node, PEWorkflowDAG.Edge> successorEdgeMap;
 
    }
}