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


C++ Header::GetKeyNew方法代码示例

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


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

示例1: GetKey

unsigned Hash::GetKey(
  const Header& header)
{
  // TRICK: 12 bits (4096) --> 132 combinations, 8 bits.
  int tFullTrick = header.GetTrickKey();
  int tRedTrick;
  if (trickKeyMap[tFullTrick] == 0)
    trickKeyMap[tFullTrick] = keyMapNo++;
  tRedTrick = trickKeyMap[tFullTrick]-1;
  assert(tFullTrick < SDS_HASH_LENTRICK);
  assert(tRedTrick < 250);

  // RANK: 12 bits ( 4096) --> 399 combinations,  9 bits.
  // RANK: 16 bits (65536) --> 593 combinations, 10 bits.
  int tFullRank = header.GetRankKey();
  int tRedRank;
  if (rankKeyMap[tFullRank] == 0)
    rankKeyMap[tFullRank] = rankMapNo++;
  tRedRank = rankKeyMap[tFullRank]-1;
  assert(tFullRank < SDS_HASH_LENRANK);
  assert(tRedRank < 1000);

  // CASE: ? bits --> 20 combinations, 5 bits.
  unsigned tFullCase = header.GetKeyNew();
  int tRedCase;
  if (caseKeyMap[tFullCase] == 0)
    caseKeyMap[tFullCase] = caseMapNo++;
  tRedCase = caseKeyMap[tFullCase]-1;
  assert(tFullCase < SDS_HASH_LENCASE);
  assert(tRedCase < 128);

  int tFullRankCase = (tRedRank << 7) | tRedCase;
  int tRedRankCase;
  if (rankCaseKeyMap[tFullRankCase] == 0)
    rankCaseKeyMap[tFullRankCase] = rankCaseMapNo++;
  tRedRankCase = rankCaseKeyMap[tFullRankCase]-1;
  assert(tFullRankCase < SDS_HASH_LENRANKCASE);
  assert(tRedRankCase < 4096);

  int key = (tRedRankCase << 8) | tRedTrick;
  assert(key < ML_MAXKEY);

  return key;
}
开发者ID:dss-bridge,项目名称:dss,代码行数:44,代码来源:Hash.cpp


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