📄 hashtbl.h
字号:
/*------------------------------------------------------------------------*/
/* */
/* HASHTBL.H */
/* */
/* Copyright Borland International 1991 */
/* All Rights Reserved */
/* */
/*------------------------------------------------------------------------*/
#if !defined( __HASHTBL_H )
#define __HASHTBL_H
#if !defined( __RESOURCE_H )
#include <Resource.h>
#endif // __RESOURCE_H
#if !defined( __CLSTYPES_H )
#include <ClsTypes.h>
#endif // __CLSTYPES_H
#if !defined( __CLSDEFS_H )
#include <ClsDefs.h>
#endif // __CLSDEFS_H
#if !defined( __COLLECT_H )
#include <Collect.h>
#endif // __COLLECT_H
#if !defined( __LIST_H )
#include <List.h>
#endif // __LIST_H
#if !defined( __VECTIMP_H )
#include <VectImp.h>
#endif // __VECTIMP_H
_CLASSDEF(ContainerIterator)
_CLASSDEF(HashTable)
_CLASSDEF(HashTableIterator)
class _CLASSTYPE HashTable : public Collection
{
public:
friend class HashTableIterator;
HashTable( sizeType = DEFAULT_HASH_TABLE_SIZE );
virtual ~HashTable() { flush(); }
virtual void add( Object _FAR & );
virtual void detach( Object _FAR &, DeleteType = NoDelete );
virtual void flush( DeleteType = DefDelete );
virtual int isEmpty() const
{
return itemsInContainer == 0;
}
virtual countType getItemsInContainer() const
{
return itemsInContainer;
}
virtual Object _FAR & findMember( Object _FAR & ) const;
virtual ContainerIterator& initIterator() const;
virtual classType isA() const
{
return hashTableClass;
}
virtual char _FAR *nameOf() const
{
return "HashTable";
}
private:
hashValueType getHashValue( Object _FAR & ) const;
sizeType size;
BI_IVectorImp<Object> table;
unsigned itemsInContainer;
DeleteType delItem( DeleteType dt )
{
return delObj(dt) ? Delete : NoDelete;
}
};
inline sizeType HashTable::getHashValue( Object _FAR & ofObject ) const
{
return ofObject.hashValue() % size;
}
class _CLASSTYPE HashTableIterator : public ContainerIterator
{
public:
HashTableIterator( const HashTable _FAR & );
~HashTableIterator();
virtual operator int();
virtual Object _FAR & current();
virtual Object _FAR & operator ++ ( int );
virtual Object _FAR & operator ++ ();
virtual void restart();
private:
BI_IVectorIteratorImp<Object> _FAR *arrayIterator;
ContainerIterator _FAR *listIterator;
const HashTable _FAR & beingIterated;
void scan();
};
#endif // __HASHTBL_H
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -