⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 hashtbl.h

📁 C++编译器,通过便编译多种文件的格式来定义出一种文件.
💻 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 + -