亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > MySQL MEM_ROOT詳解及實例代碼

MySQL MEM_ROOT詳解及實例代碼

熱門標簽:地圖標注專員入駐 如何辦理400客服電話 外呼系統怎樣才能不封號 神行者百貨商場地圖標注 西藏地圖標注改進點 外呼系統線路經常出問題嗎 安陽手機自動外呼系統原理是什么 地圖標注百度競價 地圖標注什么軟件好用

MySQL MEM_ROOT詳解

這篇文章會詳細解說MySQL中使用非常廣泛的MEM_ROOT的結構體,同時省去debug部分的信息,僅分析正常情況下,mysql中使用MEM_ROOT來做內存分配的部分。

在具體分析之前我們先例舉在該結構體使用過程中用到的一些宏:

#define MALLOC_OVERHEAD 8 //分配過程中,需要保留一部分額外的空間
#define ALLOC_MAX_BLOCK_TO_DROP 4096 //后續會繼續分析該宏的用途
#define ALLOC_MAX_BLOCK_USAGE_BEFORE_DROP 10 //后續會繼續分析該宏的用途

#define ALIGN_SIZE(A) MY_ALIGN((A),sizeof(double))
#define MY_ALIGN(A,L) (((A) + (L) - 1)  ~((L) - 1))

#define ALLOC_ROOT_MIN_BLOCK_SIZE (MALLOC_OVERHEAD + sizeof(USED_MEM) + 8)
/* Define some useful general macros (should be done after all headers). */
/*作者:www.manongjc.com */
#define MY_MAX(a, b) ((a) > (b) ? (a) : (b)) //求兩個數值之間的最大值
#define MY_MIN(a, b) ((a)  (b) ? (a) : (b)) //求兩個數值之間的最小值

下面再來看看MEM_ROOT結構體相關的信息:

typedef struct st_mem_root
{
 USED_MEM *free;         /* free block link list的鏈表頭指針 */
 USED_MEM *used;         /* used block link list的鏈表頭指針 */
 USED_MEM *pre_alloc;       /* 預先分配的block */
 size_t min_malloc;       /* 如果block剩下的可用空間小于該值,將會從free list移動到used list */
 size_t block_size;       /* 每次初始化的空間大小 */
 unsigned int block_num;       /* 記錄實際的block數量,初始化為4 */
 unsigned int first_block_usage;   /* free list中的第一個block 測試不滿足分配空間大小的次數 */
 void (*error_handler)( void );     /* 分配失敗的錯誤處理函數 */
} MEM_ROOT;

以下是分配具體的block信息.

typedef struct st_used_mem
{ 
  struct st_used_mem *next; //指向下一個分配的block
  unsigned int left; //該block剩余的空間大小
  unsigned int size; //該block的總大小
} USED_MEM;

其實MEM_ROOT在分配過程中,是通過雙向鏈表來管理used和free的block:

MEM_ROOT的初始化過程如下:

void init_alloc_root( MEM_ROOT *mem_root, size_t block_size, size_t pre_alloc_size __attribute__( (unused) ) )
{
 mem_root->free  = mem_root->used = mem_root->pre_alloc = 0;
 mem_root->min_malloc = 32;
 mem_root->block_size = block_size - ALLOC_ROOT_MIN_BLOCK_SIZE;
 mem_root->error_handler = 0;
 mem_root->block_num = 4; /* We shift this with >>2 */
 mem_root->first_block_usage = 0;
}

初始化過程中,block_size空間為block_size-ALLOC_ROOT_MIN_BLOCK_SIZE。因為在內存不夠,需要擴容時,是通過mem_root->block_num >>2 * block_size 來擴容的,所以mem_root->block_num >>2 至少為1,因此在初始化的過程中mem_root->block_num=4(注:4>>2=1)。

下面來看看具體分配內存的步驟:

void *alloc_root( MEM_ROOT *mem_root, size_t length )
{
 size_t get_size, block_size;
 uchar * point;
 reg1 USED_MEM *next = 0;
 reg2 USED_MEM **prev;

 length = ALIGN_SIZE( length );
 if ( (*(prev = mem_root->free) ) != NULL )
 {
 if ( (*prev)->left  length 
    mem_root->first_block_usage++ >= ALLOC_MAX_BLOCK_USAGE_BEFORE_DROP 
    (*prev)->left  ALLOC_MAX_BLOCK_TO_DROP )
 {
  next  = *prev;
  *prev  = next->next; /* Remove block from list */
  next->next  = mem_root->used;
  mem_root->used  = next;
  mem_root->first_block_usage = 0;
 }
 for ( next = *prev; next  next->left  length; next = next->next )
  prev = next->next;
 }
 if ( !next )
 {    /* Time to alloc new block */
 block_size = mem_root->block_size * (mem_root->block_num >> 2);
 get_size = length + ALIGN_SIZE( sizeof(USED_MEM) );
 get_size = MY_MAX( get_size, block_size );

 if ( !(next = (USED_MEM *) my_malloc( get_size, MYF( MY_WME | ME_FATALERROR ) ) ) )
 {
  if ( mem_root->error_handler )
  (*mem_root->error_handler)();
  DBUG_RETURN( (void *) 0 );               /* purecov: inspected */
 }
 mem_root->block_num++;
 next->next = *prev;
 next->size = get_size;
 next->left = get_size - ALIGN_SIZE( sizeof(USED_MEM) );  /* bug:如果該block是通過mem_root->block_size * (mem_root->block_num >> 2)計算出來的,則已經去掉了ALIGN_SIZE(sizeof(USED_MEM),這里重復了。 */
 *prev = next;
 }

 point = (uchar *) ( (char *) next + (next->size - next->left) );
/*TODO: next part may be unneded due to mem_root->first_block_usage counter*/
/* 作者:www.manongjc.com */
 if ( (next->left -= length)  mem_root->min_malloc )
 {                                    /* Full block */
 *prev  = next->next;          /* Remove block from list */
 next->next  = mem_root->used;
 mem_root->used  = next;
 mem_root->first_block_usage = 0;
 }
}

上述代碼的具體邏輯如下:

1.查看free鏈表,尋找滿足空間的block。如果找到了合適的block,則:

1.1 直接返回該block從size-left處的初始地址即可。當然,在free list遍歷的過程中,會去判斷free list
中第一個block中left的空間不滿足需要分配的空間,且該block中已經查找過了10次
(ALLOC_MAX_BLOCK_USAGE_BEFORE_DROP)都不滿足分配長度,且該block剩余空間小于
4k(ALLOC_MAX_BLOCK_TO_DROP),則將該block 移動到used鏈表中。

2.如果free鏈表中,沒有合適的block,則:

2.1 分配 mem_root->block_size * (mem_root->block_num >> 2)和length+ALIGN_SIZE(sizeof(USED_MEM))
中比較大的作為新的block內存空間。

2.2 根據該block的使用情況,將該block掛在used或者free鏈表上。

這里需要注意的是二級指針的使用:

for (next= *prev ; next  next->left  length ; next= next->next)
prev= next->next;
}

prev指向的是最后一個block的next指向的地址的地址:

所以將prev的地址替換為new block的地址,即將該new block加到了free list的結尾:*prev=next;

總結:

MEM_ROOT的內存分配采用的是啟發式分配算法,隨著后續block的數量越多,單個block的內存也會越大:block_size= mem_root->block_size * (mem_root->block_num >> 2) .

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

您可能感興趣的文章:
  • Mysql命令行導入sql數據
  • MySQL server has gone away 問題的解決方法
  • mysql中int、bigint、smallint 和 tinyint的區別詳細介紹
  • MySQL 的CASE WHEN 語句使用說明
  • MySQL創建用戶與授權方法
  • mySQL中replace的用法
  • MySQL數據庫備份與恢復方法
  • mysql 添加索引 mysql 如何創建索引
  • windows下apache+php+mysql 環境配置方法

標簽:雞西 衡水 阜陽 酒泉 萍鄉 AXB 貴港 張掖

巨人網絡通訊聲明:本文標題《MySQL MEM_ROOT詳解及實例代碼》,本文關鍵詞  MySQL,MEM,ROOT,詳解,及,實例,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL MEM_ROOT詳解及實例代碼》相關的同類信息!
  • 本頁收集關于MySQL MEM_ROOT詳解及實例代碼的相關信息資訊供網民參考!
  • 推薦文章
    成人免费网站久久久| 国产国语对白一级毛片| 色综合久久久久综合体桃花网| 一级片片| 国产一区二区精品| 深夜做爰性大片中文| 二级片在线观看| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 日本特黄特色aaa大片免费| 亚洲天堂免费观看| 精品在线视频播放| 一级毛片看真人在线视频| 国产一区二区精品久久91| 成人免费网站视频ww| 韩国毛片基地| 免费国产在线观看不卡| 精品视频一区二区三区免费| 国产成人啪精品视频免费软件| 日本特黄一级| 日日夜夜婷婷| 日韩专区第一页| 超级乱淫伦动漫| 日本在线www| 欧美1区| 欧美大片一区| 高清一级做a爱过程不卡视频| 亚洲精品中文字幕久久久久久| 欧美一级视频免费观看| 韩国三级一区| 国产国语对白一级毛片| 欧美激情一区二区三区在线播放| 日韩男人天堂| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 久久精品大片| 精品在线免费播放| 国产一区二区高清视频| 欧美大片a一级毛片视频| 国产麻豆精品视频| 青青久久精品| 国产91素人搭讪系列天堂| 国产原创视频在线| 天天色成人| 久久99这里只有精品国产| 精品视频在线看| 成人高清免费| 成人a大片高清在线观看| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 黄色短视频网站| 国产极品精频在线观看| 一级毛片视频在线观看| 青青青草影院| 国产视频一区在线| 久久久成人网| 国产综合成人观看在线| 国产高清视频免费观看| 中文字幕97| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 亚洲www美色| 欧美α片无限看在线观看免费| 日韩专区亚洲综合久久| 日本特黄特黄aaaaa大片 | 欧美激情影院| 日本在线不卡视频| 国产一区二区精品久| 精品久久久久久影院免费| 麻豆系列 在线视频| 成人免费观看的视频黄页| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 天堂网中文在线| 精品国产一区二区三区国产馆| 亚飞与亚基在线观看| 青青久久精品国产免费看| 精品国产三级a| 国产一区二区精品| 美女免费毛片| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 中文字幕一区二区三区精彩视频| 日韩中文字幕在线播放| 国产亚洲免费观看| 日本特黄特黄aaaaa大片| 久久精品店| 成人免费观看的视频黄页| 你懂的日韩| 国产伦久视频免费观看 视频| 久草免费在线色站| 亚欧视频在线| 成人免费高清视频| 亚洲爆爽| 亚洲精品久久久中文字| 日本特黄特黄aaaaa大片| 国产亚洲精品成人a在线| 欧美激情影院| 亚飞与亚基在线观看| 欧美激情伊人| 精品久久久久久综合网| 精品国产亚洲人成在线| 国产不卡高清| 99久久网站| 国产网站免费| 毛片的网站| 日韩在线观看视频黄| 亚洲 国产精品 日韩| 99色播| 国产精品1024在线永久免费| 台湾毛片| 91麻豆精品国产高清在线| 亚洲第一色在线| 欧美一级视频高清片| 国产不卡在线观看视频| 青青久久精品| 久久久久久久免费视频| 亚洲www美色| 一级女性大黄生活片免费| 国产麻豆精品hdvideoss| 免费一级片网站| 精品视频在线观看视频免费视频| 亚洲精品永久一区| 国产视频网站在线观看| 亚洲 国产精品 日韩| 99色视频| 日韩中文字幕一区二区不卡| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 国产视频网站在线观看| 久久国产精品自线拍免费| 国产一区二区高清视频| 九九热国产视频| 日日爽天天| 国产成人啪精品视频免费软件| 日本在线www| 免费一级片在线| 国产亚洲精品成人a在线| 国产不卡高清| 久草免费资源| 国产一区二区精品尤物| 毛片高清| 免费国产一级特黄aa大片在线| 国产亚洲免费观看| 亚洲第一色在线| 日韩免费片| 日韩在线观看网站| 免费的黄色小视频| 成人av在线播放| 午夜激情视频在线观看| 精品在线免费播放| 国产不卡在线观看视频| 国产一区二区精品久久| 四虎影视精品永久免费网站| 国产精品自拍在线| 久久精品成人一区二区三区| 美女免费毛片| 91麻豆爱豆果冻天美星空| 精品久久久久久中文字幕一区| 高清一级淫片a级中文字幕| 国产麻豆精品| 精品国产一区二区三区国产馆| 精品国产一级毛片| 四虎久久影院| 成人在免费观看视频国产| 欧美日本免费| 午夜激情视频在线播放| 99色视频在线观看| 精品久久久久久中文字幕2017| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 国产精品12| 韩国三级香港三级日本三级la | 一级毛片视频播放| 国产不卡在线观看视频| 亚洲精品久久久中文字| 久久精品大片| 91麻豆精品国产自产在线 | 国产亚洲精品aaa大片| 国产亚洲免费观看| 国产美女在线观看| 国产不卡在线观看| 韩国毛片基地| 日本特黄特色aaa大片免费| 国产91精品系列在线观看| 精品国产一区二区三区久久久蜜臀 | 韩国三级视频网站| 91麻豆精品国产高清在线| 亚欧乱色一区二区三区| 毛片的网站| 免费一级生活片| 日本免费乱人伦在线观看| 久久国产影院| 国产一区二区精品尤物| 国产一区二区高清视频| 国产不卡精品一区二区三区| 精品久久久久久综合网| 国产91丝袜在线播放0| 韩国三级一区| 可以免费在线看黄的网站| 国产高清在线精品一区a| 国产一区二区精品尤物| 欧美大片aaaa一级毛片| 日本在线www| 日韩免费在线视频| 久久99青青久久99久久| 韩国毛片基地| 日日日夜夜操|