Example #1
0
 /// <summary>
 /// 创建失败节点
 /// </summary>
 /// <param name="node"></param>
 private void createLink(StringTrieGraph.Node node)
 {
     if (node != null)
     {
         if (node.Link != null)
         {
             this.nodeIndex = cache[node];
             NodePool.Pool[this.nodeIndex >> ArrayPool.ArraySizeBit][this.nodeIndex & ArrayPool.ArraySizeAnd].Link = cache[node.Link];
         }
         createLink(node.Nodes);
     }
 }
Example #2
0
            /// <summary>
            /// 创建节点
            /// </summary>
            /// <param name="node"></param>
            /// <returns></returns>
            private int create(StringTrieGraph.Node node)
            {
                if (node == null)
                {
                    return(0);
                }
                if (cache.TryGetValue(node, out this.nodeIndex))
                {
                    return(this.nodeIndex);
                }
                Node[] nodes;
                cache.Add(node, this.nodeIndex = GetNodeIndex(out nodes));
                int nodeIndex = this.nodeIndex;

                nodes[nodeIndex & ArrayPool.ArraySizeAnd].Set(create(node.Nodes), node.Value);//create(node.Link)
                return(nodeIndex);
            }
Example #3
0
            /// <summary>
            /// 创建 Trie 图
            /// </summary>
            /// <param name="staticGraph"></param>
            /// <param name="graph"></param>
            internal void Create(StaticStringTrieGraph staticGraph, StringTrieGraph graph)
            {
                cache = DictionaryCreator.CreateOnly <StringTrieGraph.Node, int>();
                StringTrieGraph.Node boot = graph.Boot;
                bool isCreate             = false;

                Monitor.Enter(NodePool.Lock);
                try
                {
                    staticGraph.setBoot(create(boot));
                    createLink(boot);
                    isCreate = true;
                }
                finally
                {
                    if (isCreate || cache == null)
                    {
                        Monitor.Exit(NodePool.Lock);
                    }
                    else
                    {
                        try
                        {
                            staticGraph.CancelBuilder();
                            foreach (int index in cache.Values)
                            {
                                if (index == nodeIndex)
                                {
                                    nodeIndex = 0;
                                }
                                NodePool.Pool[index >> ArrayPool.ArraySizeBit][index & ArrayPool.ArraySizeAnd].CancelBuilder();
                            }
                            NodePool.FreeNoLock(cache.Values);
                            if (nodeIndex != 0)
                            {
                                NodePool.Pool[nodeIndex >> ArrayPool.ArraySizeBit][nodeIndex & ArrayPool.ArraySizeAnd].CancelBuilder();
                                NodePool.FreeNoLock(nodeIndex);
                            }
                        }
                        finally { Monitor.Exit(NodePool.Lock); }
                    }
                }
            }