青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

doing5552

記錄每日點滴,不枉人生一世

  C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
  73 Posts :: 0 Stories :: 94 Comments :: 0 Trackbacks

公告

常用鏈接

留言簿(24)

我參與的團隊

最新隨筆

搜索

  •  

積分與排名

  • 積分 - 456513
  • 排名 - 49

最新隨筆

最新評論

閱讀排行榜

評論排行榜

根據sgi 的STL源碼的二級分配算法改寫的內存池分配程序,只要稍微修改就可以實現共享內存方式管理,使用C++標準庫容器中的map,set,multimap,multiset測試通過,vector測試通不過,原因是在內存回收的時候考慮的比較簡單,vector每次分配內存個數不固定,回收也不固定,這樣的話,程序還需要繼續完善。

  

內存池管理程序源碼如下:

以下是引用片段:

以下是代碼片段:

#ifndef MY_ALLOCATOR_H_
#define MY_ALLOCATOR_H_
#include "stdafx.h"
#include <limits>
#include <iostream>
namespace happyever 
{
  enum { NODENUMS = 2 };
  union _Obj 
  {
    union _Obj* M_free_list_link;
    char M_client_data[1];    
  } ;
  typedef union _Obj Obj;
  struct _Cookie
  {
    int iShmKey;        /* 共享內存鍵值 */
    int iShmID;         /* iShmKey對應的shmid */
    int iSemKey;        /* 鎖信號鍵值 */
    int iSemID;         /* 鎖信號標識 */
    int iTotalsize;    /* 容器總容量 */
    void* pStartall;   /* 共享內存自身地址 */
    char* pStartfree;  /* 自由空間的開始地址*/
    char* pEndfree;    /* 自由空間的結束地址*/
    int iUseNum[NODENUMS];
    /*用來存放free_list中節點的size*/
    short sFreelistIndex[NODENUMS];
    /*存放分配內存節點的鏈表*/
    Obj* uFreelist[NODENUMS];
  };
  typedef struct _Cookie Cookie;
  //Obj;
  //Cookie;
  static Cookie *pHead = NULL;
  template <class T>
  class MyAlloc 
  {
  private:
    static const int ALIGN = sizeof(Obj);
    int round_up(int bytes);
    int freelist_index(int bytes);
    int freelist_getindex(int bytes);
    char* chunk_alloc(int size, int *nobjs);
    void* refill(int num,int n);
  public:
    // type definitions
    typedef T        value_type;
    typedef T*       pointer;
    typedef const T* const_pointer;
    typedef T&       reference;
    typedef const T& const_reference;
    typedef std::size_t    size_type;
    typedef std::ptrdiff_t difference_type;
    template <class U>
    struct rebind 
    {
      typedef MyAlloc<U> other;
    };
    pointer address (reference value) const 
    {
      return &value;
    }
    const_pointer address (const_reference value) const 
    {
      return &value;
    }
    MyAlloc() throw() 
    {
      std::cout<<"MyAlloc"<<std::endl;
    }
    MyAlloc(const MyAlloc& x) throw() 
    {
      std::cout<<"const MyAlloc"<<std::endl;
    }
    template <class U>
    MyAlloc (const MyAlloc<U>& x) throw()
    {
      std::cout<<"const MyAlloc<U>"<<std::endl;
    }
    ~MyAlloc() throw() 
    {
      std::cout<<"~MyAlloc"<<std::endl;
    }
    size_type max_size () const throw() 
    {
      return std::numeric_limits<std::size_t>::max() / sizeof(T);
    }
    //void PrintFreelistAndCookie();
    pointer allocate (size_type num, const void* = 0) 
    {
      pointer ret = 0;
      Obj** my_free_list;
      Obj* result;
      int index;
      // print message and allocate memory with global new
      std::cerr << "allocate " << num << " element(s)"
        << " of size " << sizeof(T) << std::endl;
      index = freelist_index(sizeof(T));
      if(index >= NODENUMS)
      {
        return NULL;
      }
      my_free_list = pHead->uFreelist + index;
      //Lock(semid,LOCK_NUM);
      result = *my_free_list;
      if (result == 0)
      {
        ret = (pointer)refill((int)num, round_up(sizeof(T)));
      }
      else
      {
        *my_free_list = result->M_free_list_link;
        ret = (pointer)result;
      }
      //UnLock(semid,LOCK_NUM);
      pHead->iUseNum[index] = pHead->iUseNum[index] + (int)num;
      if(0 == ret)
      {
        std::cerr << "alloc memory fail!" << std::endl;
        exit(1);
      }
      std::cerr << " allocated at: " << (void*)ret << std::endl;
      PrintFreelistAndCookie();
      return ret;
    }
    void construct (pointer p, const T& value) 
    {
      // initialize memory with placement new
      new((void*)p)T(value);
    }
    void destroy (pointer p) 
    {
      // destroy objects by calling their destructor
      p->~T();
    }
    void deallocate (pointer p, size_type num) 
    {
      Obj** my_free_list;
      Obj* q ;
      int index;
      index = freelist_getindex(sizeof(T));
      if(index >= NODENUMS)
      {
        std::cerr << "deallocate memory fail!" << std::endl;
        exit(1);
      }
      my_free_list = pHead->uFreelist + index;
      q = (Obj*) p;
      //Lock(semid,LOCK_NUM);
      /*這個地方可能會有問題*/
      //for(int i=0 ;i<(int)num ; i++)
      {
        q->M_free_list_link = *my_free_list;
        *my_free_list = q;
      }
      //UnLock(semid,LOCK_NUM);
      pHead->iUseNum[index] = pHead->iUseNum[index] - (int)num;
      
      std::cerr << "deallocate " << num << " element(s)"
        << " of size " << sizeof(T)
        << " at: " << (void*)p << std::endl;
      PrintFreelistAndCookie();
    }
  };
  template <class T>
  int MyAlloc<T>::round_up(int bytes)
  {
    int i;
    i = bytes;
    if(bytes < ALIGN)
    {
      i = ALIGN;
    }
    std::cout<<"round_up:bytes="<<bytes<<" , return="<<i<<std::endl;
    return i;
  };
  template <class T>
  int MyAlloc<T>::freelist_index(int bytes)
  {
    int i;
    for(i=0 ; i< NODENUMS ; i++)
    {
      if(pHead->sFreelistIndex[i] == bytes)
        break;
    }
    if(i >= NODENUMS)
    {
      for(i=0 ; i< NODENUMS ; i++)
      {
        if(pHead->sFreelistIndex[i] == 0)
        {
          pHead->sFreelistIndex[i] = bytes;
          std::cout<<"freelist_index:bytes="<<bytes<<" , return="<<i<<std::endl;
          return i;
        }
      }
    }
    std::cout<<"freelist_index:bytes="<<bytes<<" , return="<<i<<std::endl;
    return i;
  };
  template <class T>
  int MyAlloc<T>::freelist_getindex(int bytes)
  {
    int i;
    for(i=0 ; i< NODENUMS ; i++)
    {
      if(pHead->sFreelistIndex[i] == bytes)
        break;
    }
    std::cout<<"freelist_getindex:bytes="<<bytes<<" , return="<<i<<std::endl;
    return i;
  };
  template <class T>
  char* MyAlloc<T>::chunk_alloc(int size, int *nobjs)
  {
    char* result;
    int counts = *nobjs;
    int total_bytes = size * counts;
    int bytes_left = int(pHead->pEndfree - pHead->pStartfree);
    std::cout<<"chunk_alloc:total_bytes = "<<total_bytes
      <<",bytes_left = "<<bytes_left<<std::endl;
    if (bytes_left >= total_bytes)
    {
      result = pHead->pStartfree;
      pHead->pStartfree += total_bytes;
      std::cout<<"chunk_alloc:total_bytes = "<<total_bytes
        <<",result = "<<*result<<",start_free = "<<&(pHead->pStartfree)<<std::endl;
    }
    else if (bytes_left >= size)
    {
      counts = bytes_left/size;
      total_bytes = size * counts;
      result = pHead->pStartfree;
      pHead->pStartfree += total_bytes;
      *nobjs = counts;
      std::cout<<"chunk_alloc:total_bytes = "<<total_bytes<<",nobjs = "<<nobjs
        <<",result = "<<*result<<",start_free = "<<&(pHead->pStartfree)<<std::endl;
    }
    else
    {
      /*還需要處理回收其他空閑freelist里面的空間*/
      result = NULL;
    }
    return(result);
  };
  template <class T>
  void* MyAlloc<T>::refill(int num,int n)
  {
    int counts = num;
    int *nobjs = &counts;
    char* chunk;
    Obj** my_free_list;
    Obj* result;
    Obj* current_obj;
    Obj* next_obj;
    int i;
    chunk = chunk_alloc(n, nobjs);
    if(chunk == NULL)
    {
      return(chunk);
    }
    counts = *nobjs;
    if (1 == counts)
    {
      return(chunk);
    }
    my_free_list = pHead->uFreelist + freelist_index(n);
    result = (Obj*)chunk;
    *my_free_list = next_obj = (Obj*)(chunk + n*num);
    for (i = 1; ; i++)
    {
      current_obj = next_obj;
      next_obj = (Obj*)((char*)next_obj + n);
      if (counts - 1 == i)
      {
        current_obj->M_free_list_link = 0;
        break;
      }
      else
      {
        current_obj->M_free_list_link = next_obj;
      }
    }
    return(result);
  };
/*這個函數可以改寫成自己的共享內存分配函數*/  
static void InitShm()
  {
    int i,size=1000;
    pHead = (Cookie*)malloc(sizeof(Cookie)+size);
    pHead->iTotalsize = sizeof(Cookie)+size;
    pHead->pStartall  = pHead;
    pHead->pStartfree = (char*)pHead + sizeof(Cookie);
    pHead->pEndfree   = (char*)pHead + pHead->iTotalsize;
    for(i=0 ; i <NODENUMS ; i++)
    {
      pHead->sFreelistIndex[i]=0;
      pHead->uFreelist[i]=0;
      pHead->iUseNum[i]=0;
    }
  }
  static void PrintFreelistAndCookie()
  {
    int i,j;
    Obj* my_free_list;
    std::cout<<"Cookie info :"<<std::endl;
    std::cout<<"sizeof(struct Cookie) = "<<sizeof(Cookie)<<std::endl;
    std::cout<<"Totalsize     = "<<pHead->iTotalsize<<std::endl;
    std::cout<<"UsedSize      = "<<int(pHead->pStartfree-(char*)pHead)<<std::endl;
    std::cout<<"FreepoolSize  = "<<int(pHead->pEndfree - pHead->pStartfree)<<std::endl;
    std::cout<<"Startall      = "<<&(pHead->pStartall)<<std::endl;
    std::cout<<"Startfree     = "<<&(pHead->pStartfree)<<std::endl;
    std::cout<<"Endfree       = "<<&(pHead->pEndfree)<<std::endl;
    std::cout<<"nFreelist info :"<<std::endl;
    for(i=0 ; i<NODENUMS ; i++)
    {
      j=0;
      std::cout<<"iUseNum["<<i<<"] = "<<pHead->iUseNum[i]<<std::endl;
      std::cout<<"FreelistIndex["<<i<<"] = "<<pHead->sFreelistIndex[i]<<std::endl;
      my_free_list = pHead->uFreelist[i];
      if(my_free_list->M_client_data != 0)
      {
        while(my_free_list->M_client_data != 0)
        {
          j++;
          my_free_list = my_free_list->M_free_list_link;
        }
        std::cout<<"free_list["<<i<<"]; node counts="<<j<<std::endl;
      }
    }
  }
  template <class T1, class T2>
  bool operator== (const MyAlloc<T1>&,const MyAlloc<T2>&) throw() 
  {
    return true;
  }
  template <class T1, class T2>
  bool operator!= (const MyAlloc<T1>&,const MyAlloc<T2>&) throw() 
  {
    return false;
  }
}
#endif /*MY_ALLOCATOR_H_*/
測試程序的源碼如下:

// MyStl.cpp : 定義控制臺應用程序的入口點。
//
#include "stdafx.h"
#include <map>
#include <vector>
#include <string>
#include <utility>
#include <iostream>
#include "MyAlloc.h"
using namespace std;
int _tmain(int argc, _TCHAR* argv[])
{
  happyever ::InitShm();
  multimap<string,int,less<string>,happyever ::MyAlloc<string> > m;
  m.insert(make_pair(string("Harry"), 32));
  m.insert(make_pair(string("Mary"), 59));
  m.insert(make_pair(string("Roger"), 18));
  m.insert(make_pair(string("Nancy"), 37));
  m.insert(make_pair(string("Mary"), 23));
  
  typedef multimap<string,int,less<string>,happyever ::MyAlloc<string> >::iterator Iter;
  for (Iter p = m.begin(); p != m.end(); p++)
  {
    cout << p->first << "," << p->second << endl;
  }
  Iter p = m.find("Harry");
  m.erase(p);
  /*p = m.find("Harry");
  cout << "Harry is: " << p->second << "." << endl;*/

  for (Iter p = m.begin(); p != m.end(); p++)
  {
    cout << p->first << "," << p->second << endl;
  }
  
  return 0;
}


以上程序在vs2005,vc6上測試通過。使用MinGW編譯的時候只需要去掉vc的預編譯頭文件
#include "stdafx.h"


  即可。

  以上程序只要稍微修改,就可以實現共享內存的管理,可以方便的使用標準庫提供的容器。加上信號量的鎖機制。

  以上為了學習而改寫的SGI的stl二級分配算法實現的。以上代碼存在一定的局限性。我另外完整實現了共享內存管理的STL標準的alloctor程序,使用posix信號量加鎖。目前應用在aix的xlC編譯環境下。因為源碼涉及公司的商業秘密,所以不能公開。但基本上以上源碼已經體現了自己管理內存的完整思路,供這方面需求的朋友一起學習研究用 

posted on 2010-02-22 00:06 doing5552 閱讀(244) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲欧美成人一区二区在线电影| 亚洲午夜一区二区三区| 黄色亚洲大片免费在线观看| 亚洲无毛电影| 久久一区激情| 亚洲人人精品| 鲁大师影院一区二区三区| 欧美视频在线观看一区| 伊人久久亚洲热| 亚洲午夜精品网| 欧美成人日韩| 亚洲欧美日韩网| 欧美国产日韩精品| 亚洲性感激情| 欧美一区不卡| 国产精品二区三区四区| 亚洲人成网站在线播| 亚洲精品久久久久久下一站| 欧美性猛交xxxx乱大交蜜桃| 欧美一级成年大片在线观看| 欧美与黑人午夜性猛交久久久| 黄色成人av网| 一本久道久久综合中文字幕 | 欧美高清hd18日本| 亚洲欧美视频一区| 欧美日韩国产系列| 久久久国产午夜精品| 美女视频黄 久久| 国产在线欧美日韩| 亚洲精品你懂的| 国产精品国产亚洲精品看不卡15| 欧美一区二区三区四区夜夜大片| 亚洲精华国产欧美| 免费影视亚洲| 欧美亚洲自偷自偷| 国色天香一区二区| 99re66热这里只有精品3直播| 麻豆成人在线观看| 亚洲欧美日韩国产精品| 另类成人小视频在线| 亚洲综合三区| 欧美国产欧美亚州国产日韩mv天天看完整| 国产女精品视频网站免费| 欧美搞黄网站| 欧美韩日亚洲| 久久久久久久91| 欧美专区日韩视频| 亚洲小说欧美另类婷婷| 欧美成人蜜桃| 一区二区三区免费观看| 久久男女视频| 久久精品国亚洲| 久久久999成人| 红桃视频国产精品| 欧美成人午夜77777| 国内在线观看一区二区三区 | 久久久久五月天| 欧美一区国产一区| 亚洲一区精品视频| 欧美另类亚洲| 亚洲女优在线| 欧美吻胸吃奶大尺度电影| 最新日韩在线视频| 亚洲精品久久久久久久久久久久| 久久人体大胆视频| 亚洲精品网址在线观看| 一区二区日韩精品| 国精品一区二区三区| 午夜精品免费在线| 欧美在线观看视频在线| 香蕉久久夜色精品国产| 欧美在线播放一区二区| 狂野欧美激情性xxxx| 六月婷婷一区| 欧美日韩在线亚洲一区蜜芽 | 欧美一区视频| 国产精品一区久久久久| 久久久亚洲成人| 欧美激情中文不卡| 亚洲国产视频a| 夜夜嗨av一区二区三区网页| 欧美高清视频在线播放| 91久久精品日日躁夜夜躁国产| 亚洲日韩欧美视频一区| 欧美美女视频| 另类综合日韩欧美亚洲| 伊人激情综合| 美日韩在线观看| 欧美在线观看视频| 欧美日本一区| 欧美韩日视频| 一本久久综合亚洲鲁鲁| 国产精品伦子伦免费视频| 欧美一级久久久久久久大片| 日韩视频亚洲视频| 久久久久综合一区二区三区| 一区二区精品国产| 国产精品久久久久久久久久久久久久 | 一本到12不卡视频在线dvd| 欧美午夜大胆人体| 欧美影院在线播放| 亚洲国产日韩欧美在线动漫 | 国内伊人久久久久久网站视频| 久色婷婷小香蕉久久| 性感少妇一区| …久久精品99久久香蕉国产| 欧美伦理91i| 久久aⅴ国产欧美74aaa| 99国产麻豆精品| 国产色综合网| 欧美连裤袜在线视频| 性色av一区二区怡红| 亚洲午夜日本在线观看| 国内综合精品午夜久久资源| 欧美日韩免费在线| 久久久国产亚洲精品| 亚洲午夜久久久久久久久电影院| 蜜桃av一区二区三区| 久久这里只有精品视频首页| 国产亚洲精品一区二555| 欧美久久在线| 日韩香蕉视频| 亚洲特级毛片| 亚洲国产视频a| 欧美~级网站不卡| 亚洲高清激情| 亚洲免费电影在线观看| 国产亚洲欧美日韩美女| 欧美亚洲第一页| 制服诱惑一区二区| 午夜精品久久久久久99热软件| 国产精品大片| 欧美日韩国产丝袜另类| 免费成人av资源网| 久久人人爽爽爽人久久久| 亚洲欧美网站| 免费不卡视频| 久久精品国产第一区二区三区| 亚洲一区二区高清| 国产欧美一区在线| 欧美色视频在线| 香蕉久久夜色精品国产| 亚洲午夜激情| 中文亚洲欧美| 一区二区黄色| 老司机成人在线视频| 亚洲精品国产精品乱码不99| 在线日本欧美| 亚洲国产99精品国自产| 欧美日本网站| 欧美在线日韩精品| 欧美一级视频精品观看| 亚洲高清电影| 亚洲精品久久久久中文字幕欢迎你 | 久久狠狠婷婷| 久久先锋影音| 国产精品99久久久久久白浆小说| 国产精品毛片a∨一区二区三区| 久久成人亚洲| 亚洲精品美女久久7777777| 亚洲国产小视频| 久久一区激情| 亚洲一区区二区| 亚洲精品综合久久中文字幕| 国产欧美精品在线| 韩日欧美一区二区三区| 欧美日韩一区不卡| 国产精品久久77777| 欧美成人午夜剧场免费观看| 亚洲欧美日本国产有色| 欧美在线观看视频一区二区| 久久国产福利国产秒拍| 夜夜嗨av色综合久久久综合网| 久久中文欧美| 亚欧美中日韩视频| 亚洲图片欧洲图片av| 亚洲国产精品传媒在线观看| 国产亚洲网站| 国产精品丝袜白浆摸在线| 红桃av永久久久| 国产日韩精品视频一区二区三区| 国产一区二区久久| 国产精品一区免费观看| 亚洲成色www久久网站| 亚洲深爱激情| 亚洲午夜激情| 久久婷婷国产综合国色天香| 亚洲欧美国产一区二区三区| 久久亚洲影音av资源网| 欧美在线观看www| 亚洲国产专区校园欧美| 亚洲欧美日韩另类精品一区二区三区| 亚洲人成人一区二区在线观看| 亚洲综合成人在线| 欧美激情片在线观看| 欧美成人免费一级人片100| 国产美女扒开尿口久久久| 国产精品网曝门| 日韩视频在线观看国产| 亚洲精品美女在线观看|