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


Java HashFunction類代碼示例

本文整理匯總了Java中com.google.common.hash.HashFunction的典型用法代碼示例。如果您正苦於以下問題:Java HashFunction類的具體用法?Java HashFunction怎麽用?Java HashFunction使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


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

示例1: isFullDuplicate

import com.google.common.hash.HashFunction; //導入依賴的package包/類
public boolean isFullDuplicate(IHttpRequestResponse messageInfo) {
    PrintWriter stdout = new PrintWriter(callbacks.getStdout(), true);
    IResponseInfo respInfo = helpers.analyzeResponse(messageInfo.getResponse());

    if (dubBloomFilter == null) return false;

    HashFunction m_hash = Hashing.murmur3_32();
    if (helpers.bytesToString(messageInfo.getResponse()).length() > respInfo.getBodyOffset()) {
        String body = helpers.bytesToString(messageInfo.getResponse()).substring(respInfo.getBodyOffset());

        /* full-dub detection */
        String dedupHashValue = m_hash.hashBytes(helpers.stringToBytes(body)).toString();
        if (dubBloomFilter.mightContain(dedupHashValue)) {
            return true;
        }
        dubBloomFilter.put(dedupHashValue);
    }

    return false;
}
 
開發者ID:yandex,項目名稱:burp-molly-scanner,代碼行數:21,代碼來源:EntryPointDeduplicator.java

示例2: getJarFilePrefix

import com.google.common.hash.HashFunction; //導入依賴的package包/類
/**
 * Files exported from jars are exported into a certain folder so that we can rebuild them
 * when the related jar file changes.
 */
@NonNull
private static String getJarFilePrefix(@NonNull File inputFile) {
    // get the filename
    String name = inputFile.getName();
    // remove the extension
    int pos = name.lastIndexOf('.');
    if (pos != -1) {
        name = name.substring(0, pos);
    }

    // add a hash of the original file path.
    String input = inputFile.getAbsolutePath();
    HashFunction hashFunction = Hashing.sha1();
    HashCode hashCode = hashFunction.hashString(input, Charsets.UTF_16LE);

    return name + "-" + hashCode.toString();
}
 
開發者ID:alibaba,項目名稱:atlas,代碼行數:22,代碼來源:AwbDataBindingMergeArtifactsTask.java

示例3: fingerprintMac

import com.google.common.hash.HashFunction; //導入依賴的package包/類
/**
 * Build a stringified MAC address using the ClusterMetadata hash for uniqueness.
 * Form of MAC is "02:eb" followed by four bytes of clusterMetadata hash.
 */
static String fingerprintMac(ClusterMetadata cm) {
    if (cm == null) {
        return DEFAULT_MAC;
    }

    HashFunction hf = Hashing.murmur3_32();
    HashCode hc = hf.newHasher().putObject(cm, ClusterMetadata.HASH_FUNNEL).hash();
    int unqf = hc.asInt();

    StringBuilder sb = new StringBuilder();
    sb.append("02:eb");
    for (int i = 0; i < 4; i++) {
        byte b = (byte) (unqf >> i * 8);
        sb.append(String.format(":%02X", b));
    }
    return sb.toString();
}
 
開發者ID:shlee89,項目名稱:athena,代碼行數:22,代碼來源:ProbedLinkProvider.java

示例4: configureHash

import com.google.common.hash.HashFunction; //導入依賴的package包/類
private static HashFunction configureHash(Algorithm alg, long seedNSalt, long addlSipSeed) {
	switch (alg) {
	case xxHash64:
		return new xxHashFunction(seedNSalt);
	case Murmur3_128:
		return Hashing.murmur3_128((int) seedNSalt);
	case Murmur3_32:
		return Hashing.murmur3_32((int) seedNSalt);
	case sha256:
		return Hashing.sha1();
	case sipHash24:
		return Hashing.sipHash24(seedNSalt, addlSipSeed);
	default:
		throw new IllegalArgumentException("Invalid Enum Hashing Algorithm???");
	}
}
 
開發者ID:MGunlogson,項目名稱:CuckooFilter4J,代碼行數:17,代碼來源:SerializableSaltedHasher.java

示例5: getDirectoryNameForJar

import com.google.common.hash.HashFunction; //導入依賴的package包/類
/**
 * Chooses a directory name, based on a JAR file name, considering exploded-aar and classes.jar.
 */

public static String getDirectoryNameForJar(File inputFile) {
    // add a hash of the original file path.
    HashFunction hashFunction = Hashing.sha1();
    HashCode hashCode = hashFunction.hashString(inputFile.getAbsolutePath(), Charsets.UTF_16LE);

    String name = Files.getNameWithoutExtension(inputFile.getName());
    if (name.equals("classes") && inputFile.getAbsolutePath().contains("exploded-aar")) {
        // This naming scheme is coming from DependencyManager#computeArtifactPath.
        File versionDir = inputFile.getParentFile().getParentFile();
        File artifactDir = versionDir.getParentFile();
        File groupDir = artifactDir.getParentFile();

        name = Joiner.on('-').join(
                groupDir.getName(), artifactDir.getName(), versionDir.getName());
    }
    name = name + "_" + hashCode.toString();
    return name;
}
 
開發者ID:dodola,項目名稱:AnoleFix,代碼行數:23,代碼來源:FileUtils.java

示例6: getJackFileName

import com.google.common.hash.HashFunction; //導入依賴的package包/類
/**
 * Returns a unique File for the converted library, even if there are 2 libraries with the same
 * file names (but different paths)
 *
 * @param outFolder the output folder.
 * @param inputFile the library
 */
@NonNull
public static File getJackFileName(@NonNull File outFolder, @NonNull File inputFile) {
    // get the filename
    String name = inputFile.getName();
    // remove the extension
    int pos = name.lastIndexOf('.');
    if (pos != -1) {
        name = name.substring(0, pos);
    }

    // add a hash of the original file path.
    String input = inputFile.getAbsolutePath();
    HashFunction hashFunction = Hashing.sha1();
    HashCode hashCode = hashFunction.hashString(input, Charsets.UTF_16LE);

    return new File(outFolder, name + "-" + hashCode.toString() + SdkConstants.DOT_JAR);
}
 
開發者ID:jskierbi,項目名稱:intellij-ce-playground,代碼行數:25,代碼來源:JillTask.java

示例7: HashElement_GivenTestString_ReturnHash

import com.google.common.hash.HashFunction; //導入依賴的package包/類
@Test
public void HashElement_GivenTestString_ReturnHash() throws Exception {
    // Arrange
    byte[] elementToHash = "test".getBytes();

    HashFunction hashFunction = mock(HashFunction.class, RETURNS_DEEP_STUBS);
    when(hashFunction.hashBytes(eq(elementToHash))).thenReturn(HashCode.fromLong(10L));

    Guava64BitHasher hasher = new Guava64BitHasher(hashFunction);

    // Act
    Hash64Bits hash = hasher.hash(elementToHash);

    // Assert
    Hash64Bits expectedHash = new Hash64Bits(10L);

    assertEquals(expectedHash, hash);
}
 
開發者ID:inigoillan,項目名稱:libanalytics,代碼行數:19,代碼來源:Guava64BitHasherTest.java

示例8: Hash_GivenTestString_ReturnHash

import com.google.common.hash.HashFunction; //導入依賴的package包/類
@Test
public void Hash_GivenTestString_ReturnHash() throws Exception {
    // Arrange
    byte[] elementToHash = "test".getBytes();

    HashFunction hashFunction = mock(HashFunction.class, RETURNS_DEEP_STUBS);
    when(hashFunction.hashBytes(eq(elementToHash))).thenReturn(HashCode.fromInt(10));

    Guava32BitHasher hasher = new Guava32BitHasher(hashFunction);

    // Act
    Hash32Bits hash = hasher.hash(elementToHash);

    // Assert
    Hash32Bits expectedHash = new Hash32Bits(10);

    assertEquals(expectedHash, hash);
}
 
開發者ID:inigoillan,項目名稱:libanalytics,代碼行數:19,代碼來源:Guava32BitHasherTest.java

示例9: getHash

import com.google.common.hash.HashFunction; //導入依賴的package包/類
static double getHash(String newString){
	double hashofString = 0;
	try{
		// The murmur hash is an effective way to uniformly hash different string
		HashFunction hf = Hashing.murmur3_128();
		HashCode hc = hf.newHasher().putString(newString).hash();
		byte[] byteArray = hc.asBytes();
		ByteBuffer buffer = ByteBuffer.wrap(byteArray);
		hashofString = buffer.getShort();

	}
	catch(Exception e){
		e.printStackTrace();
	}
	return Math.abs(hashofString)%.99;

}
 
開發者ID:rchakra3,項目名稱:TomR,代碼行數:18,代碼來源:ConsistentHashing.java

示例10: getKeyHash

import com.google.common.hash.HashFunction; //導入依賴的package包/類
static double getKeyHash(String newString){
	double hashofString = 0;
	try{
		// The murmur hash is an effective way to uniformly hash different string
		HashFunction hf = Hashing.murmur3_128();
		HashCode hc = hf.newHasher().putString(newString).hash();
		byte[] byteArray = hc.asBytes();
		ByteBuffer buffer = ByteBuffer.wrap(byteArray);
		hashofString = buffer.getShort();

	}
	catch(Exception e){
		e.printStackTrace();
	}
	return Math.abs(hashofString)%.99;

}
 
開發者ID:rchakra3,項目名稱:TomR,代碼行數:18,代碼來源:ConsistentHashing.java

示例11: HashEngine

import com.google.common.hash.HashFunction; //導入依賴的package包/類
/**
 * Construct a new hash engine, using the default configuration values
 * present in the the hrfs site configuration file.
 */
public HashEngine(HashFunction hfn)
{
	this.conf = new HrfsConfiguration();
	this.hashfn = hfn;
	this.nworkers = conf.getInt(HrfsKeys.HRFS_HENGINE_WORKERS, 5);

	this.biqueue = new ConcurrentLinkedQueue<Block>();
	this.boqueue = new ConcurrentLinkedQueue<DataBlock>();
	this.ahcnt = new AtomicLong(0);
	
	/* Build up our worker pool using the configuration tunable. */
	this.executor = new ThreadPoolExecutor(nworkers, nworkers,
					       1000L, TimeUnit.MILLISECONDS,
					       new LinkedBlockingQueue<Runnable>());
}
 
開發者ID:WillDignazio,項目名稱:hrfs,代碼行數:20,代碼來源:HashEngine.java

示例12: calculatePartition

import com.google.common.hash.HashFunction; //導入依賴的package包/類
/**
 * Distribute triggers on nodes using a consistent hashing strategy.
 * This strategy allows to scale and minimize changes and re-distribution when cluster changes.
 *
 * @param entries a list of entries to distribute
 * @param buckets a table of nodes
 * @return a map of entries distributed across nodes
 */
public Map<PartitionEntry, Integer> calculatePartition(List<PartitionEntry> entries,
                                                       Map<Integer, Integer> buckets) {
    if (entries == null) {
        throw new IllegalArgumentException("entries must be not null");
    }
    if (isEmpty(buckets)) {
        throw new IllegalArgumentException("entries must be not null");
    }
    HashFunction md5 = Hashing.md5();
    int numBuckets = buckets.size();
    Map<PartitionEntry, Integer> newPartition = new HashMap<>();
    for (PartitionEntry entry : entries) {
        newPartition.put(entry, buckets.get(Hashing.consistentHash(md5.hashInt(entry.hashCode()), numBuckets)));
    }
    return newPartition;
}
 
開發者ID:hawkular,項目名稱:hawkular-alerts,代碼行數:25,代碼來源:PartitionManagerImpl.java

示例13: getHasher

import com.google.common.hash.HashFunction; //導入依賴的package包/類
public static HashFunction getHasher(HashType hashType) {
  switch(hashType) {
    case MURMUR3_128:
      return Hashing.murmur3_128();
    case MURMUR3_32:
      return Hashing.murmur3_32();
    case SIPHASH24:
      return Hashing.sipHash24();
    case MD5:
      return Hashing.md5();
    case SHA1:
      return Hashing.sha1();
    case SHA256:
      return Hashing.sha256();
    case SHA512:
      return Hashing.sha512();
    case ADLER32:
      return Hashing.adler32();
    case CRC32:
      return Hashing.crc32();
    case CRC32C:
      return Hashing.crc32c();
    default:
      throw new IllegalArgumentException(Utils.format("Unsupported Hashing Algorithm: {}", hashType.name()));
  }
}
 
開發者ID:streamsets,項目名稱:datacollector,代碼行數:27,代碼來源:HashingUtil.java

示例14: generateHash

import com.google.common.hash.HashFunction; //導入依賴的package包/類
private String generateHash(
    Record record,
    HashType hashType,
    Collection<String> fieldsToHash,
    boolean includeRecordHeader,
    boolean useSeparator
) throws StageException {
  try {
    HashFunction hasher = HashingUtil.getHasher(hashType.getHashType());
    HashingUtil.RecordFunnel recordFunnel = HashingUtil.getRecordFunnel(
        fieldsToHash,
        includeRecordHeader,
        useSeparator
    );
    return hasher.hashObject(record, recordFunnel).toString();
  } catch (IllegalArgumentException e) {
    throw new OnRecordErrorException(Errors.HASH_00, hashType.getDigest(), e.toString(), e);
  }
}
 
開發者ID:streamsets,項目名稱:datacollector,代碼行數:20,代碼來源:FieldHasherProcessor.java

示例15: hashForRecordsWithFieldsAndHeaderAttr

import com.google.common.hash.HashFunction; //導入依賴的package包/類
private String hashForRecordsWithFieldsAndHeaderAttr(
    Record record,
    Collection<String> fieldsToHash,
    HashType hashType,
    boolean includeRecordHeaderForHashing,
    boolean useSeparator
) {
  HashFunction hasher = HashingUtil.getHasher(hashType.getHashType());
  Set<String> validFieldsToHash = new HashSet<>();
  for (String fieldPath : fieldsToHash) {
    Field field = record.get(fieldPath);
    Field.Type type = field.getType();
    if (!(FieldHasherProcessor.UNSUPPORTED_FIELD_TYPES.contains(type) || field.getValue() == null)) {
      validFieldsToHash.add(fieldPath);
    }
  }
  HashingUtil.RecordFunnel recordFunnel =
      HashingUtil.getRecordFunnel(
          validFieldsToHash,
          includeRecordHeaderForHashing,
          useSeparator
      );
  return hasher.hashObject(record, recordFunnel).toString();
}
 
開發者ID:streamsets,項目名稱:datacollector,代碼行數:25,代碼來源:TestFieldHasherProcessor.java


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