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

📄 oblist.h

📁 一个很好的协议,数据包解码工具,可以分析7号(ISUP,MTP,...), TCP/UDP等各种协议,特别的是还能支持自定义的二进制数据报,可以通过插件无限扩充协议库.
💻 H
字号:
/*==================================================================
=  文件名  :
=  主要功能: 提供对指针类型数据的动态链表操作          
=  修改日期: 2005-10                                            
=  作者    : shen beide
====================================================================*/

#if !defined(_OBLIST_H)
#define _OBLIST_H

#include <stdio.h>
#include <stdlib.h>

#include "PubHeader.h"
#include "Base.h"
#include "otstr.h"

///////////////////////////////////////
class DLNode_
{
private:
    void*       p_data; 
    DWORD       wparam;
    DLNode_*    p_next;      
    DLNode_*    p_prev;      
    
public:
    DLNode_();
    DLNode_(void* data,DWORD param);

    inline void  setNULL();

    inline void* getdata(DWORD* lpParam=NULL);
    inline void  setdata(void* data,DWORD param); 

    inline DLNode_* next(void) const; 
    inline DLNode_* prev(void) const; 
    
    inline void  setnext(DLNode_* next); 
    inline void  setprev(DLNode_* prev); 
};

///////////////////////////////////////
///////////////////////////////////////
#ifdef _DLL_PROJECT
class CLASS_EXPORT ObList: public TName
#else
class ObList: public TName
#endif
{
private:
    DLNode_*      p_head;        //First node in the list. 
    DLNode_*      p_tail;        //Last  node in the list. 
    long          nodenum;

    unsigned long poolsize;
    DLNode_*      p_idlehead;    //First idlenode in the list. 
    long          idlenodenum;
    
public:
    ObList();
   ~ObList(); 

    void  Setpoolsize(unsigned long default_poolsize=0); 
                      // poolsize=0 时, 直接使用系统 new, delete 
                      // poolsize>0 时, 采用优化静态内存分配, 可以提高分配效率
    long  GetCount();
    bool  IsEmpty();  
       
    void  AddHead(void* data, DWORD param=0);   //!! 添加时指针是否重复不做检查
    void  AddTail(void* data, DWORD param=0);

    void* GetHead(DWORD* lpParam=NULL);
    void* GetTail(DWORD* lpParam=NULL);
    void* GetAt(long nIndex,DWORD* lpParam=NULL);

    void* RemoveHead(DWORD* lpParam=NULL);
    void* RemoveTail(DWORD* lpParam=NULL);
    void  RemoveAll();

    OTSTR ShowAllListNode();
        
private:
    inline DLNode_* GetHeadNode(void) const ;
    inline DLNode_* GetTailNode(void) const ;

    inline DLNode_* MallocNode(void* data, DWORD param=0);
    inline void     FreeNode(DLNode_* pNode);
};

///////////////////////////////////////////////////
///////////////////////////////////////////////////

#ifdef _DLL_PROJECT
template<class TYPE>
class CLASS_EXPORT TObList: public ObList
#else
template<class TYPE>
class TObList: public ObList
#endif
{
public:
    TObList()  { };
    
    //////////////////////////////////////
   ~TObList()  { };
    
    //////////////////////////////////////
    TYPE* GetHead(DWORD* lpParam=NULL)
    {
        return (TYPE*)ObList::GetHead(lpParam);
    }
    TYPE* GetTail(DWORD* lpParam=NULL)
    {
        return (TYPE*)ObList::GetTail(lpParam);
    }
    TYPE* GetAt(long nIndex,DWORD* lpParam=NULL)
    {
        return (TYPE*)ObList::GetAt(nIndex,lpParam);
    }
    
    TYPE* RemoveHead(DWORD* lpParam=NULL)
    {
        return (TYPE*)ObList::RemoveHead(lpParam);
    }
    TYPE* RemoveTail(DWORD* lpParam=NULL)
    {
        return (TYPE*)ObList::RemoveTail(lpParam);
    }
};


#endif






















⌨️ 快捷键说明

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