Start line:  
End line:  

Snippet Preview

Snippet HTML Code

Stack Overflow Questions
Copyright (c) 2000, 2009 IBM Corporation and others. All rights reserved. This program and the accompanying materials are made available under the terms of the Eclipse Public License v1.0 which accompanies this distribution, and is available at http://www.eclipse.org/legal/epl-v10.html Contributors: IBM Corporation - initial API and implementation /
 
 package org.eclipse.jdt.internal.compiler.util;

 
Hashtable for non-zero long keys.
 
 
 public final class HashtableOfLong {
 	// to avoid using Enumerations, walk the individual tables skipping nulls
 	public long[] keyTable;
 	public Object[] valueTable;
 
 	public int elementSize// number of elements in the table
 	int threshold;
 public HashtableOfLong() {
 	this(13);
 }
 public HashtableOfLong(int size) {
 	this. = 0;
 	this. = size// size represents the expected number of elements
 	int extraRoom = (int) (size * 1.75f);
 	if (this. == extraRoom)
 		extraRoom++;
 	this. = new long[extraRoom];
 	this. = new Object[extraRoom];
 }
 public boolean containsKey(long key) {
 	int length = this..length,
 		index = ((int)(key >>> 32)) % length;
 	long currentKey;
 	while ((currentKey = this.[index]) != 0) {
 		if (currentKey == key)
 			return true;
 		if (++index == length) {
 			index = 0;
 		}
 	}
 	return false;
 }
 public Object get(long key) {
 	int length = this..length,
 		index = ((int)(key >>> 32)) % length;
 	long currentKey;
 	while ((currentKey = this.[index]) != 0) {
 		if (currentKey == key)  return this.[index];
 		if (++index == length) {
 			index = 0;
 		}
 	}
 	return null;
 }
 public Object put(long keyObject value) {
 	int length = this..length,
 		index = ((int)(key >>> 32)) % length;
 	long currentKey;
 	while ((currentKey = this.[index]) != 0) {
 		if (currentKey == key)  return this.[index] = value;
 		if (++index == length) {
 			index = 0;
 		}
 	}
 	this.[index] = key;
 	this.[index] = value;
 
 	// assumes the threshold is never equal to the size of the table
 	if (++this. > this.)
 		rehash();
 	return value;
 }
 private void rehash() {
 	HashtableOfLong newHashtable = new HashtableOfLong(this. * 2); // double the number of expected elements
 	long currentKey;
 	for (int i = this..length; --i >= 0;)
 		if ((currentKey = this.[i]) != 0)
 			newHashtable.put(currentKeythis.[i]);
 
 	this. = newHashtable.keyTable;
 	this. = newHashtable.valueTable;
 	this. = newHashtable.threshold;
 }
 public int size() {
 	return this.;
 }
 public String toString() {
 	String s = ""//$NON-NLS-1$
 	Object object;
 	for (int i = 0, length = this..lengthi < lengthi++)
 		if ((object = this.[i]) != null)
 			s += this.[i] + " -> " + object.toString() + "\n"//$NON-NLS-2$ //$NON-NLS-1$
 	return s;
New to GrepCode? Check out our FAQ X