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

📄 jk_pool.h

📁 Tomcat 4.1与WebServer集成组件的源代码包.
💻 H
字号:
/* ========================================================================= * *                                                                           * *                 The Apache Software License,  Version 1.1                 * *                                                                           * *          Copyright (c) 1999-2001 The Apache Software Foundation.          * *                           All rights reserved.                            * *                                                                           * * ========================================================================= * *                                                                           * * Redistribution and use in source and binary forms,  with or without modi- * * fication, are permitted provided that the following conditions are met:   * *                                                                           * * 1. Redistributions of source code  must retain the above copyright notice * *    notice, this list of conditions and the following disclaimer.          * *                                                                           * * 2. Redistributions  in binary  form  must  reproduce the  above copyright * *    notice,  this list of conditions  and the following  disclaimer in the * *    documentation and/or other materials provided with the distribution.   * *                                                                           * * 3. The end-user documentation  included with the redistribution,  if any, * *    must include the following acknowlegement:                             * *                                                                           * *       "This product includes  software developed  by the Apache  Software * *        Foundation <http://www.apache.org/>."                              * *                                                                           * *    Alternately, this acknowlegement may appear in the software itself, if * *    and wherever such third-party acknowlegements normally appear.         * *                                                                           * * 4. The names  "The  Jakarta  Project",  "Jk",  and  "Apache  Software     * *    Foundation"  must not be used  to endorse or promote  products derived * *    from this  software without  prior  written  permission.  For  written * *    permission, please contact <apache@apache.org>.                        * *                                                                           * * 5. Products derived from this software may not be called "Apache" nor may * *    "Apache" appear in their names without prior written permission of the * *    Apache Software Foundation.                                            * *                                                                           * * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESSED OR IMPLIED WARRANTIES * * INCLUDING, BUT NOT LIMITED TO,  THE IMPLIED WARRANTIES OF MERCHANTABILITY * * AND FITNESS FOR  A PARTICULAR PURPOSE  ARE DISCLAIMED.  IN NO EVENT SHALL * * THE APACHE  SOFTWARE  FOUNDATION OR  ITS CONTRIBUTORS  BE LIABLE  FOR ANY * * DIRECT,  INDIRECT,   INCIDENTAL,  SPECIAL,  EXEMPLARY,  OR  CONSEQUENTIAL * * DAMAGES (INCLUDING,  BUT NOT LIMITED TO,  PROCUREMENT OF SUBSTITUTE GOODS * * OR SERVICES;  LOSS OF USE,  DATA,  OR PROFITS;  OR BUSINESS INTERRUPTION) * * HOWEVER CAUSED AND  ON ANY  THEORY  OF  LIABILITY,  WHETHER IN  CONTRACT, * * STRICT LIABILITY, OR TORT  (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN * * ANY  WAY  OUT OF  THE  USE OF  THIS  SOFTWARE,  EVEN  IF  ADVISED  OF THE * * POSSIBILITY OF SUCH DAMAGE.                                               * *                                                                           * * ========================================================================= * *                                                                           * * This software  consists of voluntary  contributions made  by many indivi- * * duals on behalf of the  Apache Software Foundation.  For more information * * on the Apache Software Foundation, please see <http://www.apache.org/>.   * *                                                                           * * ========================================================================= *//*************************************************************************** * Description: Memory Pool object header file                             * * Author:      Gal Shachor <shachor@il.ibm.com>                           * * Version:     $Revision: 1.8 $                                           * ***************************************************************************/#ifndef _JK_POOL_H#define _JK_POOL_H#include "jk_global.h"#include "jk_env.h"#ifdef __cplusplusextern "C" {#endif /* __cplusplus *//** * @file jk_pool.h * @brief Jk memory allocation * * Similar with apr_pools, but completely unsynchronized. * XXX use same names *  *//* * The pool atom (basic pool alocation unit) is an 8 byte long.  * Each allocation (even for 1 byte) will return a round up to the  * number of atoms.  *  * This is to help in alignment of 32/64 bit machines ... * G.S */#ifdef WIN32    typedef __int64     jk_pool_atom_t;#elif defined(AIX)    typedef long long   jk_pool_atom_t;#elif defined(SOLARIS)    typedef long long   jk_pool_atom_t;#elif defined(LINUX)    typedef long long   jk_pool_atom_t;#elif defined(FREEBSD)    typedef long long   jk_pool_atom_t;#elif defined(OS2)    typedef long long   jk_pool_atom_t;#elif defined(NETWARE)    typedef long long   jk_pool_atom_t;#elif defined(HPUX11)    typedef long long   jk_pool_atom_t;#elif defined(IRIX)    typedef long long   jk_pool_atom_t;#elif defined(AS400)    typedef void *		jk_pool_atom_t;#else    typedef long long   jk_pool_atom_t;#endif/*  * Pool size in number of pool atoms. */#define TINY_POOL_SIZE 256                  /* Tiny 1/4K atom pool. */#define SMALL_POOL_SIZE 512                 /* Small 1/2K atom pool. */#define BIG_POOL_SIZE   2*SMALL_POOL_SIZE   /* Bigger 1K atom pool. */#define HUGE_POOL_SIZE  2*BIG_POOL_SIZE     /* Huge 2K atom pool. */struct jk_pool;struct jk_env;typedef struct jk_pool jk_pool_t;/** The pool can grow by (m)allocating more storage, but it'll first use buf.*/struct jk_pool {    /** Create a child pool. Size is a hint for the     *  estimated needs of the child.     */    jk_pool_t *(*create)(struct jk_env *env, jk_pool_t *_this,                         int size );        void (*close)(struct jk_env *env, jk_pool_t *_this);    /** Empty the pool using the same space.     *  XXX should we rename it to clear() - consistent with apr ?     */    void (*reset)(struct jk_env *env, jk_pool_t *_this);    /* Memory allocation */        void *(*alloc)(struct jk_env *env, jk_pool_t *_this, size_t size);    void *(*realloc)(struct jk_env *env, jk_pool_t *_this, size_t size,                     const void *old, size_t old_sz);    void *(*calloc)(struct jk_env *env, jk_pool_t *_this, size_t size);    void *(*pstrdup)(struct jk_env *env, jk_pool_t *_this, const char *s);    void *(*pstrdup2ascii)(struct jk_env *env, jk_pool_t *_this, const char *s);    void *(*pstrdup2ebcdic)(struct jk_env *env, jk_pool_t *_this, const char *s);    /** Points to the private data. In the case of APR,        it's a apr_pool you can use directly */    void *_private;};/** Create a pool. Use it for the initial allocation ( in mod_jk ). All other    pools should be created using the virtual method.    XXX move this to the factory */int jk2_pool_create( struct jk_env *env, jk_pool_t **newPool, jk_pool_t *parent, int size );int JK_METHOD jk2_pool_apr_create( struct jk_env *env, struct jk_pool **newPool,                                   struct jk_pool *parent, void *aprPool );#ifdef __cplusplus}#endif /* __cplusplus */#endif /* _JK_POOL_H */

⌨️ 快捷键说明

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