259 lines
3.9 KiB
C++
259 lines
3.9 KiB
C++
|
/*++
|
||
|
|
||
|
Copyright (c) 1992 Microsoft Corporation
|
||
|
|
||
|
Module Name:
|
||
|
|
||
|
membmgr.hxx
|
||
|
|
||
|
Abstract:
|
||
|
|
||
|
This class offers two classes for the management of fixed
|
||
|
size blocks of memory. The first class STATIC_MEM_BLOCK_MGR
|
||
|
allows the user to allocate and free fixed size memory blocks
|
||
|
up to the specified limit that the class was initialized to.
|
||
|
|
||
|
The second class MEM_BLOCK_MGR offers a scheme for memory block
|
||
|
management that will grow as the clients needs increase.
|
||
|
|
||
|
Author:
|
||
|
|
||
|
Norbert P. Kusters (norbertk) 29-May-92
|
||
|
|
||
|
--*/
|
||
|
|
||
|
#if !defined(_MEM_BLOCK_MGR_DEFN_)
|
||
|
|
||
|
#define _MEM_BLOCK_MGR_DEFN_
|
||
|
|
||
|
|
||
|
#include "array.hxx"
|
||
|
#include "bitvect.hxx"
|
||
|
|
||
|
|
||
|
DECLARE_CLASS( STATIC_MEM_BLOCK_MGR );
|
||
|
|
||
|
class STATIC_MEM_BLOCK_MGR : public OBJECT {
|
||
|
|
||
|
public:
|
||
|
|
||
|
DECLARE_CONSTRUCTOR( STATIC_MEM_BLOCK_MGR );
|
||
|
|
||
|
VIRTUAL
|
||
|
~STATIC_MEM_BLOCK_MGR(
|
||
|
);
|
||
|
|
||
|
NONVIRTUAL
|
||
|
BOOLEAN
|
||
|
Initialize(
|
||
|
IN ULONG MemBlockSize,
|
||
|
IN ULONG NumBlocks DEFAULT 128
|
||
|
);
|
||
|
|
||
|
NONVIRTUAL
|
||
|
PVOID
|
||
|
Alloc(
|
||
|
);
|
||
|
|
||
|
NONVIRTUAL
|
||
|
BOOLEAN
|
||
|
Free(
|
||
|
OUT PVOID MemBlock
|
||
|
);
|
||
|
|
||
|
NONVIRTUAL
|
||
|
ULONG
|
||
|
QueryBlockSize(
|
||
|
) CONST;
|
||
|
|
||
|
NONVIRTUAL
|
||
|
ULONG
|
||
|
QueryNumBlocks(
|
||
|
) CONST;
|
||
|
|
||
|
private:
|
||
|
|
||
|
NONVIRTUAL
|
||
|
VOID
|
||
|
Construct(
|
||
|
);
|
||
|
|
||
|
NONVIRTUAL
|
||
|
VOID
|
||
|
Destroy(
|
||
|
);
|
||
|
|
||
|
PCHAR _heap;
|
||
|
ULONG _num_blocks;
|
||
|
ULONG _block_size;
|
||
|
ULONG _num_allocated;
|
||
|
ULONG _next_alloc;
|
||
|
BITVECTOR _bitvector;
|
||
|
|
||
|
};
|
||
|
|
||
|
|
||
|
INLINE
|
||
|
ULONG
|
||
|
STATIC_MEM_BLOCK_MGR::QueryBlockSize(
|
||
|
) CONST
|
||
|
/*++
|
||
|
|
||
|
Routine Description:
|
||
|
|
||
|
This routine return the number of bytes in a block returned
|
||
|
by this object.
|
||
|
|
||
|
Arguments:
|
||
|
|
||
|
None.
|
||
|
|
||
|
Return Value:
|
||
|
|
||
|
The number of bytes per block.
|
||
|
|
||
|
--*/
|
||
|
{
|
||
|
return _block_size;
|
||
|
}
|
||
|
|
||
|
|
||
|
INLINE
|
||
|
ULONG
|
||
|
STATIC_MEM_BLOCK_MGR::QueryNumBlocks(
|
||
|
) CONST
|
||
|
/*++
|
||
|
|
||
|
Routine Description:
|
||
|
|
||
|
This routine return the number of blocks contained
|
||
|
by this object.
|
||
|
|
||
|
Arguments:
|
||
|
|
||
|
None.
|
||
|
|
||
|
Return Value:
|
||
|
|
||
|
The number of blocks.
|
||
|
|
||
|
--*/
|
||
|
{
|
||
|
return _num_blocks;
|
||
|
}
|
||
|
|
||
|
|
||
|
|
||
|
DECLARE_CLASS( MEM_BLOCK_MGR );
|
||
|
|
||
|
class MEM_BLOCK_MGR : public OBJECT {
|
||
|
|
||
|
public:
|
||
|
|
||
|
ULIB_EXPORT
|
||
|
DECLARE_CONSTRUCTOR( MEM_BLOCK_MGR );
|
||
|
|
||
|
VIRTUAL
|
||
|
ULIB_EXPORT
|
||
|
~MEM_BLOCK_MGR(
|
||
|
);
|
||
|
|
||
|
NONVIRTUAL
|
||
|
ULIB_EXPORT
|
||
|
BOOLEAN
|
||
|
Initialize(
|
||
|
IN ULONG MemBlockSize,
|
||
|
IN ULONG InitialNumBlocks DEFAULT 128
|
||
|
);
|
||
|
|
||
|
NONVIRTUAL
|
||
|
ULIB_EXPORT
|
||
|
PVOID
|
||
|
Alloc(
|
||
|
);
|
||
|
|
||
|
NONVIRTUAL
|
||
|
ULIB_EXPORT
|
||
|
BOOLEAN
|
||
|
Free(
|
||
|
OUT PVOID MemBlock
|
||
|
);
|
||
|
|
||
|
NONVIRTUAL
|
||
|
ULONG
|
||
|
QueryBlockSize(
|
||
|
) CONST;
|
||
|
|
||
|
private:
|
||
|
|
||
|
NONVIRTUAL
|
||
|
VOID
|
||
|
Construct(
|
||
|
);
|
||
|
|
||
|
NONVIRTUAL
|
||
|
VOID
|
||
|
Destroy(
|
||
|
);
|
||
|
|
||
|
PSTATIC_MEM_BLOCK_MGR _static_mem_list[32];
|
||
|
|
||
|
};
|
||
|
|
||
|
|
||
|
INLINE
|
||
|
ULONG
|
||
|
MEM_BLOCK_MGR::QueryBlockSize(
|
||
|
) CONST
|
||
|
/*++
|
||
|
|
||
|
Routine Description:
|
||
|
|
||
|
This routine return the number of bytes in a block returned
|
||
|
by this object.
|
||
|
|
||
|
Arguments:
|
||
|
|
||
|
None.
|
||
|
|
||
|
Return Value:
|
||
|
|
||
|
The number of bytes per block.
|
||
|
|
||
|
--*/
|
||
|
{
|
||
|
return _static_mem_list[0] ? _static_mem_list[0]->QueryBlockSize() : 0;
|
||
|
}
|
||
|
|
||
|
|
||
|
INLINE
|
||
|
PVOID
|
||
|
operator new(
|
||
|
IN size_t Size,
|
||
|
IN PVOID Pointer
|
||
|
)
|
||
|
/*++
|
||
|
|
||
|
Routine Description:
|
||
|
|
||
|
This is an explicit placement version of the 'new' operator
|
||
|
which clients of these classes may wish to use in order to
|
||
|
call the constructor on their newly allocated objects.
|
||
|
|
||
|
Arguments:
|
||
|
|
||
|
Size - Supplies the size of the buffer.
|
||
|
Pointer - Supplies a pointer to the buffer.
|
||
|
|
||
|
Return Value:
|
||
|
|
||
|
This function returns the passed in pointer.
|
||
|
|
||
|
--*/
|
||
|
{
|
||
|
return Pointer;
|
||
|
}
|
||
|
|
||
|
|
||
|
#endif // _MEM_BLOCK_MGR_DEFN_
|