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

📄 ncbi_heapmgr.h

📁 ncbi源码
💻 H
字号:
/* * =========================================================================== * PRODUCTION $Log: ncbi_heapmgr.h,v $ * PRODUCTION Revision 1000.0  2003/10/29 16:30:57  gouriano * PRODUCTION PRODUCTION: IMPORTED [ORIGINAL] Dev-tree R6.19 * PRODUCTION * =========================================================================== */#ifndef CONNECT___NCBI_HEAPMGR__H#define CONNECT___NCBI_HEAPMGR__H/*  $Id: ncbi_heapmgr.h,v 1000.0 2003/10/29 16:30:57 gouriano Exp $ * =========================================================================== * *                            PUBLIC DOMAIN NOTICE *               National Center for Biotechnology Information * *  This software/database is a "United States Government Work" under the *  terms of the United States Copyright Act.  It was written as part of *  the author's official duties as a United States Government employee and *  thus cannot be copyrighted.  This software/database is freely available *  to the public for use. The National Library of Medicine and the U.S. *  Government have not placed any restriction on its use or reproduction. * *  Although all reasonable efforts have been taken to ensure the accuracy *  and reliability of the software and data, the NLM and the U.S. *  Government do not and cannot warrant the performance or results that *  may be obtained by using this software or data. The NLM and the U.S. *  Government disclaim all warranties, express or implied, including *  warranties of performance, merchantability or fitness for any particular *  purpose. * *  Please cite the author in any work or product based on this material. * * =========================================================================== * * Author:  Anton Lavrentiev, Denis Vakatov * * File Description: *   Simple heap manager with a primitive garbage collection * */#include <connect/ncbi_types.h>/** @addtogroup ServiceSupport * * @{ */#ifdef __cplusplusextern "C" {#endif/* Heap handle */struct SHEAP_tag;typedef struct SHEAP_tag* HEAP;/* Header of a heap block */typedef struct {    unsigned int flag;  /* (short)flag == 0 if block is vacant              */    TNCBI_Size   size;  /* size of the block (including the block header)   */} SHEAP_Block;/* Callback to expand the heap (a la 'realloc'). * NOTE: the returned address must be aligned on a 'double' boundary! * *   old_base  |  new_size  |  Expected result * ------------+------------+-------------------------------------------------- *   non-NULL  |     0      | Deallocate old_base and return 0 *   non-NULL  |  non-zero  | Reallocate to the requested size, return new base *      0      |  non-zero  | Allocate (newly) and return base *      0      |     0      | Do nothing, return 0 * ------------+------------+-------------------------------------------------- * Note that reallocation can request either to expand or to shrink the * heap extent. When (re-)allocation fails, the callback should return 0. * When expected to return 0, this callback has to always do so. */typedef void* (*FHEAP_Expand)(void*      old_base,  /* current base of the heap to be expanded           */ TNCBI_Size new_size,  /* requested new heap size (zero to deallocate heap) */ void*      arg        /* user-supplied argument, see HEAP_Create() below   */ );/* Create new heap. * NOTE: the initial heap base must be aligned on a 'double' boundary! */extern NCBI_XCONNECT_EXPORT HEAP HEAP_Create(void*        base,        /* initial heap base (use "expand" if NULL) */ TNCBI_Size   size,        /* initial heap size                        */ TNCBI_Size   chunk_size,  /* minimal increment size                   */ FHEAP_Expand expand,      /* NULL if not expandable                   */ void*        arg          /* arg to pass to expand (if any)           */ );/* Attach to an already existing heap (in read-only mode). */extern NCBI_XCONNECT_EXPORT HEAP HEAP_Attach(const void* base          /* base of the heap to attach to */ );extern NCBI_XCONNECT_EXPORT HEAP HEAP_AttachEx(const void* base, TNCBI_Size  size );/* Allocate a new block of memory in the heap. */extern NCBI_XCONNECT_EXPORT SHEAP_Block* HEAP_Alloc(HEAP       heap,          /* heap handle                       */ TNCBI_Size size           /* data size of the block to contain */ );/* Deallocate block pointed by "block_ptr". */extern NCBI_XCONNECT_EXPORT void HEAP_Free(HEAP         heap,        /* heap handle         */ SHEAP_Block* block_ptr    /* block to deallocate */ );/* Iterate through the heap blocks. * Return pointer to the block following block "prev_block". * Return NULL if "prev_block" is the last block of the heap. */extern NCBI_XCONNECT_EXPORT SHEAP_Block* HEAP_Walk(const HEAP         heap,  /* heap handle                                  */ const SHEAP_Block* prev   /* (if 0, then get the first block of the heap) */ );/* Trim the heap, making garbage collection first. Returned is * the size of the resultant heap, which has its last block trimmed * to the size of heap chunk size as specified at the time of the * heap creation. No change in size is made if the last block is * not free or large enough to allow the trimming. 0 returned on * NULL or read-only heaps, or if an error has occurred. */extern NCBI_XCONNECT_EXPORT TNCBI_Size HEAP_Trim(HEAP heap);/* Make a snapshot of a given heap. Return a read-only heap * (like one after HEAP_Attach), which must be freed by a call to * either HEAP_Detach or HEAP_Destroy when no longer needed. * If a non-zero number provided (serial number) it is stored * in the heap descriptor (zero serial is always turned into 1). */extern NCBI_XCONNECT_EXPORT HEAP HEAP_CopySerial(const HEAP orig,         /* original heap to copy from               */ size_t     extra,        /* extra amount to add past the heap extent */ int        serial        /* serial number to assign (default is 1)   */ );#define HEAP_Copy(orig) HEAP_CopySerial(orig, 0, 0)/* Detach heap (previously attached by HEAP_Attach). */extern NCBI_XCONNECT_EXPORT void HEAP_Detach(HEAP heap);/* Destroy heap (previously created by HEAP_Create). */extern NCBI_XCONNECT_EXPORT void HEAP_Destroy(HEAP heap);/* Get base address of the heap */extern NCBI_XCONNECT_EXPORT void* HEAP_Base(const HEAP heap);/* Get the extent of the heap */extern NCBI_XCONNECT_EXPORT TNCBI_Size HEAP_Size(const HEAP heap);/* Get non-zero serial number of the heap. * Return 0 if HEAP is passed as 0, or the heap is not a copy but original. */extern NCBI_XCONNECT_EXPORT int HEAP_Serial(const HEAP heap);#ifdef __cplusplus} /* extern "C" */#endif/* @} *//* * -------------------------------------------------------------------------- * $Log: ncbi_heapmgr.h,v $ * Revision 1000.0  2003/10/29 16:30:57  gouriano * PRODUCTION: IMPORTED [ORIGINAL] Dev-tree R6.19 * * Revision 6.19  2003/09/23 21:00:53  lavr * +HEAP_AttachEx() * * Revision 6.18  2003/09/02 20:45:45  lavr * -<connect/connect_export.h> -- now included from <connect/ncbi_types.h> * * Revision 6.17  2003/08/28 21:09:37  lavr * Accept (and allocate) additional heap extent in HEAP_CopySerial() * * Revision 6.16  2003/08/25 14:50:10  lavr * Heap arena ptrs changed to be "void*";  expand routine to take user arg * * Revision 6.15  2003/07/31 17:53:43  lavr * +HEAP_Trim() * * Revision 6.14  2003/04/09 17:58:51  siyan * Added doxygen support * * Revision 6.13  2003/01/08 01:59:32  lavr * DLL-ize CONNECT library for MSVC (add NCBI_XCONNECT_EXPORT) * * Revision 6.12  2002/09/25 20:08:43  lavr * Added table to explain expand callback inputs and outputs * * Revision 6.11  2002/09/19 18:00:58  lavr * Header file guard macro changed; log moved to the end * * Revision 6.10  2002/04/13 06:33:22  lavr * +HEAP_Base(), +HEAP_Size(), +HEAP_Serial(), new HEAP_CopySerial() * * Revision 6.9  2001/07/03 20:23:46  lavr * Added function: HEAP_Copy() * * Revision 6.8  2001/06/19 20:16:19  lavr * Added #include <connect/ncbi_types.h> * * Revision 6.7  2001/06/19 19:09:35  lavr * Type change: size_t -> TNCBI_Size; time_t -> TNCBI_Time * * Revision 6.6  2000/10/05 21:25:45  lavr * ncbiconf.h removed * * Revision 6.5  2000/10/05 21:09:52  lavr * ncbiconf.h included * * Revision 6.4  2000/05/23 21:41:05  lavr * Alignment changed to 'double' * * Revision 6.3  2000/05/12 18:28:40  lavr * First working revision * * ========================================================================== */#endif /* CONNECT___NCBI_HEAPMGR__H */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -