當前位置: 首頁>>代碼示例>>Java>>正文


Java Set.hashCode方法代碼示例

本文整理匯總了Java中java.util.Set.hashCode方法的典型用法代碼示例。如果您正苦於以下問題:Java Set.hashCode方法的具體用法?Java Set.hashCode怎麽用?Java Set.hashCode使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在java.util.Set的用法示例。


在下文中一共展示了Set.hashCode方法的7個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: main

import java.util.Set; //導入方法依賴的package包/類
public static void main(String[] args) throws Exception {
    final ConcurrentHashMap<String, String> concurrentHashMap =
        new ConcurrentHashMap<>();

    concurrentHashMap.put("One", "Un");
    concurrentHashMap.put("Two", "Deux");
    concurrentHashMap.put("Three", "Trois");

    Set<Map.Entry<String, String>> entrySet = concurrentHashMap.entrySet();
    HashSet<Map.Entry<String, String>> hashSet = new HashSet<>(entrySet);

    if (false == hashSet.equals(entrySet)) {
        throw new RuntimeException("Test FAILED: Sets are not equal.");
    }
    if (hashSet.hashCode() != entrySet.hashCode()) {
        throw new RuntimeException("Test FAILED: Set's hashcodes are not equal.");
    }
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:19,代碼來源:DistinctEntrySetElements.java

示例2: hashCode

import java.util.Set; //導入方法依賴的package包/類
@Override
public int hashCode() {
  // Warning: this is broken if size() == 0, so it is critical that we
  // substitute an empty ImmutableSet to the user in place of this

  // It's a weird formula, but tests prove it works.
  int adjust = size() - 1;
  for (int i = 0; i < axes.size(); i++) {
    adjust *= 31;
    adjust = ~~adjust;
    // in GWT, we have to deal with integer overflow carefully
  }
  int hash = 1;
  for (Set<E> axis : axes) {
    hash = 31 * hash + (size() / axis.size() * axis.hashCode());

    hash = ~~hash;
  }
  hash += adjust;
  return ~~hash;
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:22,代碼來源:Sets.java

示例3: _calculateStableHashCode

import java.util.Set; //導入方法依賴的package包/類
/**
 * Because Enums don't have stable hash codes, we can't use their hash code directly.  Instead
 * we want to use the has code of the enum's name, which should be stable.  Here we essentially
 * duplicate the hash code calculation of Map, using the stable hash code instead
 * @return stable hash code
 */
private static int _calculateStableHashCode(final Map<TrinidadAgent.Application, Set<AgentMatcher>> selectorAgents,
                                            final Set<AgentMatcher> capTouchMatchers)
{
  int hashCode = 0;

  // Map hash code is defined as the additive hash code of the entries
  for (Map.Entry<TrinidadAgent.Application, Set<AgentMatcher>> entry : selectorAgents.entrySet())
  {
    // use the enum's name to have a stable hash code
    int stableKeyHashCode = entry.getKey().name().hashCode();

    // entry hash code is defined as the XOR of the key and value.
    int entryHashCode = stableKeyHashCode ^ entry.getValue().hashCode();

    hashCode += entryHashCode;
  }

  hashCode += capTouchMatchers.hashCode();

  return hashCode;
}
 
開發者ID:apache,項目名稱:myfaces-trinidad,代碼行數:28,代碼來源:AgentAtRuleMatcher.java

示例4: main

import java.util.Set; //導入方法依賴的package包/類
public static void main(String[] args) throws Exception {
    final IdentityHashMap<String, String> identityHashMap =
        new IdentityHashMap<>();

    identityHashMap.put("One", "Un");
    identityHashMap.put("Two", "Deux");
    identityHashMap.put("Three", "Trois");

    Set<Map.Entry<String, String>> entrySet = identityHashMap.entrySet();
    HashSet<Map.Entry<String, String>> hashSet = new HashSet<>(entrySet);

    // NB: These comparisons are valid in this case because none of the
    //     keys put into 'identityHashMap' above are equal to any other.
    if (false == hashSet.equals(entrySet)) {
        throw new RuntimeException("Test FAILED: Sets are not equal.");
    }
    if (hashSet.hashCode() != entrySet.hashCode()) {
        throw new RuntimeException("Test FAILED: Set's hashcodes are not equal.");
    }
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:21,代碼來源:DistinctEntrySetElements.java

示例5: main

import java.util.Set; //導入方法依賴的package包/類
public static void main(String[] args) throws Exception {
    final EnumMap<TestEnum, String> enumMap = new EnumMap<>(TestEnum.class);

    for (TestEnum e : TestEnum.values()) {
        enumMap.put(e, e.name());
    }

    Set<Map.Entry<TestEnum, String>> entrySet = enumMap.entrySet();
    HashSet<Map.Entry<TestEnum, String>> hashSet = new HashSet<>(entrySet);

    if (false == hashSet.equals(entrySet)) {
        throw new RuntimeException("Test FAILED: Sets are not equal.");
    }
    if (hashSet.hashCode() != entrySet.hashCode()) {
        throw new RuntimeException("Test FAILED: Set's hashcodes are not equal.");
    }
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:18,代碼來源:DistinctEntrySetElements.java

示例6: hashCode

import java.util.Set; //導入方法依賴的package包/類
@Override
public int hashCode() {
    final int prime = 31;
    int result = 1;
    Set<TypeLabel> labelSet = this.labelSet;
    result = prime * result + ((labelSet == null) ? 0 : labelSet.hashCode());
    result = prime * result + (this.negated ? 1231 : 1237);
    result = prime * result + this.var.hashCode();
    return result;
}
 
開發者ID:meteoorkip,項目名稱:JavaGraph,代碼行數:11,代碼來源:TypeGuard.java

示例7: testSecureSetHashCode

import java.util.Set; //導入方法依賴的package包/類
private static void testSecureSetHashCode() {
    System.out.println("------ SecureSet.hashCode() -----");

    Subject subj = makeSubj(false, false, false);

    // Make sure two other Set types that we know are equal per
    // SecureSet.equals() and verify their hashCodes are also the same
    Set<Principal> equalHashSet = new HashSet<>(Arrays.asList(princVals));

    if (subj.getPrincipals().hashCode() != equalHashSet.hashCode()) {
        throw new RuntimeException(
                "SecureSet and HashSet hashCodes() differ");
    }
    System.out.println("SecureSet.hashCode() tests passed");
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:16,代碼來源:SubjectNullTests.java


注:本文中的java.util.Set.hashCode方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。