Extendible hashing—a fast access method for dynamic files

Extendible hashing is a new access technique, in which the user is guaranteed no more than two page faults to locate the data associated with a given unique identifier, or key. Unlike conventional hashing, extendible hashing has a dynamic structure that grows and shrinks gracefully as the database grows and shrinks. This approach simultaneously solves the problem of making hash tables that are extendible and of making radix search trees that are balanced. We study, by analysis and simulation, the performance of extendible hashing. The results indicate that extendible hashing provides an attractive alternative to other access methods, such as balanced trees.

[1]  Allen Newell,et al.  The logic theory machine-A complex information processing system , 1956, IRE Trans. Inf. Theory.

[2]  Edward Fredkin,et al.  Trie memory , 1960, Commun. ACM.

[3]  M. AdelsonVelskii,et al.  AN ALGORITHM FOR THE ORGANIZATION OF INFORMATION , 1963 .

[4]  S. M. Samuels,et al.  Some inequalities among binomial and Poisson probabilities , 1967 .

[5]  Donald Ervin Knuth,et al.  The Art of Computer Programming , 1968 .

[6]  Aleksandr I︠A︡kovlevich Khinchin,et al.  Mathematical methods in the theory of queueing , 1969 .

[7]  Irving L. Traiger,et al.  Evaluation Techniques for Storage Hierarchies , 1970, IBM Syst. J..

[8]  Gary D. Knott,et al.  Expandable open addressing hash table storage and retrieval , 1971, SIGFIDET '71.

[9]  Edward M. Reingold,et al.  Binary search trees of bounded balance , 1972, SIAM J. Comput..

[10]  Edward M. Reingold,et al.  Binary Search Trees of Bounded Balance , 1973, SIAM J. Comput..

[11]  A. Nijenhuis Combinatorial algorithms , 1975 .

[12]  Wayne Allan Walker Hybrid trees as a data structure. , 1975 .

[13]  Larry Carter,et al.  Universal classes of hash functions (Extended Abstract) , 1977, STOC '77.

[14]  Larry Carter,et al.  Analysis of a Universal Class of Hash Functions , 1978, MFCS.

[15]  Donald Ervin Knuth,et al.  The Art of Computer Programming, 2nd Ed. (Addison-Wesley Series in Computer Science and Information , 1978 .

[16]  Per-Åke Larson,et al.  Dynamic hashing , 1978, BIT.

[17]  Witold Litwin,et al.  Virtual Hashing: A Dynamically Changing Hashing , 1978, VLDB.

[18]  Larry Carter,et al.  Universal Classes of Hash Functions , 1979, J. Comput. Syst. Sci..