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


C# Slice.GetHashCode方法代码示例

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


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

示例1: TestGetHashCodeIsZeroForEmptySlice

        public void TestGetHashCodeIsZeroForEmptySlice()
        {
            var s = new Slice<int>(new int[0]);
            Assert.AreEqual(0, s.GetHashCode());

            s = new Slice<int>(new[] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 });
            s = s.Slc(5, 5);
            Assert.AreEqual(0, s.Len());
            Assert.AreEqual(0, s.GetHashCode());
        }
开发者ID:yonglehou,项目名称:NsqSharp,代码行数:10,代码来源:SliceTest.cs

示例2: TestGetHashCodeIsCalculating

        public void TestGetHashCodeIsCalculating()
        {
            var s = new Slice<int>(new[] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 });
            int hash1 = s.GetHashCode();

            s = new Slice<int>(new[] { 1, 2, 3, 4, 5 });
            int hash2 = s.GetHashCode();

            Assert.AreNotEqual(0, hash1);
            Assert.AreNotEqual(0, hash2);
            Assert.AreNotEqual(hash1, hash2);
        }
开发者ID:yonglehou,项目名称:NsqSharp,代码行数:12,代码来源:SliceTest.cs

示例3: InsertAsync

		public async Task InsertAsync([NotNull] IFdbTransaction trans, Slice key)
		{
			if (trans == null) throw new ArgumentNullException("trans");

			if (await ContainsAsync(trans, key).ConfigureAwait(false))
			{
				return;
			}

			int keyHash = key.GetHashCode(); //TODO: proper hash function?
			//Console.WriteLine("Inserting " + key + " with hash " + keyHash.ToString("x"));
			for(int level = 0; level < MAX_LEVELS; level++)
			{
				var prevKey = await GetPreviousNodeAsync(trans, level, key);

				if ((keyHash & ((1 << (level * LEVEL_FAN_POW)) - 1)) != 0)
				{
					//Console.WriteLine("> [" + level + "] Incrementing previous key: " + FdbKey.Dump(prevKey));
					trans.AtomicAdd(this.Subspace.Partition(level, prevKey), EncodeCount(1));
				}
				else
				{
					//Console.WriteLine("> [" + level + "] inserting and updating previous key: " + FdbKey.Dump(prevKey));
					// Insert into this level by looking at the count of the previous
					// key in the level and recounting the next lower level to correct
					// the counts
					var prevCount = DecodeCount(await trans.GetAsync(this.Subspace.Pack(level, prevKey)).ConfigureAwait(false));
					var newPrevCount = await SlowCountAsync(trans, level - 1, prevKey, key);
					var count = checked((prevCount - newPrevCount) + 1);

					// print "insert", key, "level", level, "count", count,
					// "splits", prevKey, "oldC", prevCount, "newC", newPrevCount
					trans.Set(this.Subspace.Pack(level, prevKey), EncodeCount(newPrevCount));
					trans.Set(this.Subspace.Pack(level, key), EncodeCount(count));
				}
			}
		}
开发者ID:BedeGaming,项目名称:foundationdb-dotnet-client,代码行数:37,代码来源:FdbRankedSet.cs


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