当前位置: 首页>>代码示例>>C#>>正文


C# Hash.GetNibble方法代码示例

本文整理汇总了C#中Hash.GetNibble方法的典型用法代码示例。如果您正苦于以下问题:C# Hash.GetNibble方法的具体用法?C# Hash.GetNibble怎么用?C# Hash.GetNibble使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Hash的用法示例。


在下文中一共展示了Hash.GetNibble方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: NodeExists

        /// <summary>
        /// Traverse down tree to see the availability of given leaf node.
        /// </summary>
        /// <param name="ID"></param>
        /// <returns></returns>
        public bool NodeExists(Hash ID)
        {
            TreeNode<LeafDataType> TempRoot = Root;

            int HLEN = ID.Hex.Length << 1; // Multiply by 2

            for (int i = 0; i < HLEN; i++)
            {
                byte Nibble = ID.GetNibble(i);

                if ((i < (HLEN - 1)))
                {
                    if (TempRoot.Children[Nibble] == null)
                    {
                        return false;
                    }

                    TempRoot = TempRoot.Children[Nibble];
                }

                if (i == (HLEN - 1))
                {
                    if ((TempRoot.Children[Nibble] != null) && TempRoot.Children[Nibble].IsLeaf)
                    {
                        return true;
                    }
                    else
                    {
                        return false;
                    }
                }
            }

            return false;
        }
开发者ID:dipamchang,项目名称:tnetd-open,代码行数:40,代码来源:HashTree.cs

示例2: TraverseToLeaf

        /// <summary>
        /// Traverses to a leaf node.
        /// </summary>
        /// <param name="ID"></param>
        /// <param name="Leaf"></param>
        /// <returns></returns>
        private TraverseResult TraverseToLeaf(Hash ID, out ListTreeLeafNode Leaf)
        {
            ListTreeNode TempRoot = Root;

            int LeafDepth = Constants.HashTree_NodeListDepth;

            for (int i = 0; i < LeafDepth; i++)
            {
                byte Nibble = ID.GetNibble(i);

                if ((i < (LeafDepth - 1)))
                {
                    if (TempRoot.Children[Nibble] == null)
                    {
                        Leaf = default(ListTreeLeafNode);
                        return TraverseResult.MidwayBreak;
                    }

                    TempRoot = TempRoot.Children[Nibble];
                }

                if (i == (LeafDepth - 1))
                {
                    if ((TempRoot.Children[Nibble] != null) && TempRoot.Children[Nibble].IsLeaf)
                    {
                        Leaf = (ListTreeLeafNode)TempRoot.Children[Nibble];
                        return TraverseResult.Success;
                    }
                    else
                    {
                        Leaf = default(ListTreeLeafNode);
                        return TraverseResult.LeafDoesNotExist;
                    }
                }
            }

            Leaf = default(ListTreeLeafNode);
            return TraverseResult.NodeDoesNotExist;
        }
开发者ID:dipamchang,项目名称:tnetd-open,代码行数:45,代码来源:ListHashTree.cs

示例3: GetNodeData

        /// <summary>
        /// Gets the element at the position specified by the ID.
        /// </summary>
        /// <param name="ID"></param>
        /// <returns></returns>
        public LeafDataType GetNodeData(Hash ID)
        {
            TreeNode<LeafDataType> TempRoot = Root;

            int HLEN = ID.Hex.Length << 1; // Multiply by 2

            for (int i = 0; i < HLEN; i++)
            {
                byte Nibble = ID.GetNibble(i);

                if ((i < (HLEN - 1)))
                {
                    if (TempRoot.Children[Nibble] == null) throw new Exception("Node does not exist. Midway Break");

                    TempRoot = TempRoot.Children[Nibble];
                }

                if (i == (HLEN - 1))
                {
                    if ((TempRoot.Children[Nibble] != null) && TempRoot.Children[Nibble].IsLeaf)
                    {
                        TreeLeafNode<LeafDataType> TLN = (TreeLeafNode<LeafDataType>)TempRoot.Children[Nibble];
                        return TLN.Value;
                    }
                    else
                    {
                        throw new Exception("Node does not exist.");
                    }
                }
            }

            throw new Exception("Node does not exist.");
        }
开发者ID:dipamchang,项目名称:tnetd-open,代码行数:38,代码来源:HashTree.cs


注:本文中的Hash.GetNibble方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。