中文字幕第二一区_久久久久在线视频_精品国产自在现线看久久_亚洲精品一区二区三区电影网

產品分類

當前位置: 首頁 > 工業電氣產品 > 端子與連接器 > 汽車連接器

類型分類:
科普知識
數據分類:
汽車連接器

淺析malloc()的幾種實現方式

發布日期:2022-04-27 點擊率:126

    malloc()是C語言中動態存儲管理的一組標準庫函數之一。其作用是在內存的動態存儲區中分配一個長度為size的連續空間。其參數是一個無符號整形數,返回值是一個指向所分配的連續存儲域的起始地址的指針。 

  動態內存分配就是指在程序執行的過程中動態地分配或者回收存儲空間的分配內存的方法。動態內存分配不像數組等靜態內存分配方法那樣需要預先分配存儲空間,而是由系統根據程序的需要即時分配,且分配的大小就是程序要求的大小。本文簡單介紹動態內存分配函數malloc()及幾種實現方法。

  1. 簡介

  malloc()是C語言中動態存儲管理的一組標準庫函數之一。其作用是在內存的動態存儲區中分配一個長度為size的連續空間。其參數是一個無符號整形數,返回值是一個指向所分配的連續存儲域的起始地址的指針。還有一點必須注意的是,當函數未能成功分配存儲空間(如內存不足)就會返回一個NULL指針。所以在調用該函數時應該檢測返回值是否為NULL并執行相應的操作。

  2. 函數說明

  C語言的動態存儲管理由一組標準庫函數實現,其原型在標準文件<stdlib.h>里描述,需要用這些功 
能時應包含這個文件。與動態存儲分配有關的函數共有四個,其中就包括存儲分配函數malloc()。函數原型是:void *malloc (size_t n);這里的size_t是標準庫里定義的一個類型,它是一個無符號整型。這個整型能夠滿足所有對存儲塊大小描述的需要,具體相當于哪個整型由具體的C系統確定。malloc的返回值為(void *)類型(這是通用指針的一個重要用途),它分配一片能存放大小為n的數據的存儲塊,返回對應的指針值;如果不能滿足申請(找不到能滿足要求的存儲塊)就返回NULL。在使用時,應該把malloc的返回值轉換到特定指針類型,賦給一個指針。

  注意,雖然這里的存儲塊是通過動態分配得到的,但是它的大小也是確定的,同樣不允許越界使用。例如上面程序段分配的塊里能存n個雙精度數據,隨后的使用就必須在這個范圍內進行。越界使用動態分配的存儲塊,尤其是越界賦值,可能引起非常嚴重的后果,通常會破壞程序的運行系統,可能造成本程序或者整個計算機系統垮臺。

  下例是一個動態分配的例子:
  #include <stdlib.h>

  main()
  {
  int count,*array; /*count是一個計數器,array是一個整型指針,也可以理解為指向一個整型數組的首地址*/
  if((array(int *) malloc (10*sizeof(int)))==NULL)
  {
  printf("不能成功分配存儲空間。");
  exit(1);
  }
  for (count=0;count〈10;count++) /*給數組賦值*/
  array[count]=count;
  for(count=0;count〈10;count++) /*打印數組元素*/
  printf("%2d",array[count]);
  } 

  上例中動態分配了10個整型存儲區域,然后進行賦值并打印。例中if((array(int *) malloc (10*sizeof(int)))==NULL)語句可以分為以下幾步:
  1)分配10個整型的連續存儲空間,并返回一個指向其起始地址的整型指針
  2)把此整型指針地址賦給array
  3)檢測返回值是否為NULL

  3. malloc()工作機制

  malloc函數的實質體現在,它有一個將可用的內存塊連接為一個長長的列表的所謂空閑鏈表。調用malloc函數時,它沿連接表尋找一個大到足以滿足用戶請求所需要的內存塊。然后,將該內存塊一分為二(一塊的大小與用戶請求的大小相等,另一塊的大小就是剩下的字節)。接下來,將分配給用戶的那塊內存傳給用戶,并將剩下的那塊(如果有的話)返回到連接表上。調用free函數時,它將用戶釋放的內存塊連接到空閑鏈上。到最后,空閑鏈會被切成很多的小內存片段,如果這時用戶申請一個大的內存片段,那么空閑鏈上可能沒有可以滿足用戶要求的片段了。于是,malloc函數請求延時,并開始在空閑鏈上翻箱倒柜地檢查各內存片段,對它們進行整理,將相鄰的小空閑塊合并成較大的內存塊。

  4. malloc()在操作系統中的實現

  在 C 程序中,多次使用malloc () 和 free()。不過,您可能沒有用一些時間去思考它們在您的操作系統中是如何實現的。本節將向您展示 malloc 和 free 的一個最簡化實現的代碼,來幫助說明管理內存時都涉及到了哪些事情。

  在大部分操作系統中,內存分配由以下兩個簡單的函數來處理:

  void *malloc (long numbytes):該函數負責分配 numbytes 大小的內存,并返回指向第一個字節的指針。

  void free(void *firstbyte):如果給定一個由先前的 malloc 返回的指針,那么該函數會將分配的空間歸還給進程的“空閑空間”。

  malloc_init 將是初始化內存分配程序的函數。它要完成以下三件事:將分配程序標識為已經初始化,找到系統中最后一個有效內存地址,然后建立起指向我們管理的內存的指針。這三個變量都是全局變量:

  清單 1. 我們的簡單分配程序的全局變量

  int has_initialized = 0;
  void *managed_memory_start;
  void *last_valid_address;


  如前所述,被映射的內存的邊界(最后一個有效地址)常被稱為系統中斷點或者 當前中斷點。在很多 UNIX? 系統中,為了指出當前系統中斷點,必須使用 sbrk(0) 函數。 sbrk 根據參數中給出的字節數移動當前系統中斷點,然后返回新的系統中斷點。使用參數 0 只是返回當前中斷點。這里是我們的 malloc 初始化代碼,它將找到當前中 
斷點并初始化我們的變量:


  清單 2. 分配程序初始化函數
  /* Include the sbrk function */

  #include 
  void malloc_init()
  {
  /* grab the last valid address from the OS */
  last_valid_address = sbrk(0);
  /* we don't have any memory to manage yet, so
  *just set the beginning to be last_valid_address
  */
  managed_memory_start = last_valid_address;
  /* Okay, we're initialized and ready to go */
  has_initialized = 1;
  }


  現在,為了完全地管理內存,我們需要能夠追蹤要分配和回收哪些內存。在對內存塊進行了 free 調用之后,我們需要做的是諸如將它們標記為未被使用的等事情,并且,在調用 malloc 時,我們要能夠定位未被使用的內存塊。因此, malloc 返回的每塊內存的起始處首先要有這個結構:


  清單 3. 內存控制塊結構定義
  struct mem_control_block {
  int is_available;
  int size;
  };


  現在,您可能會認為當程序調用 malloc 時這會引發問題 —— 它們如何知道這個結構?答案是它們不必知道;在返回指針之前,我們會將其移動到這個結構之后,把它隱藏起來。這使得返回的指針指向沒有用于任何其他用途的內存。那樣,從調用程序的角度來看,它們所得到的全部是空閑的、開放的內存。然后,當通過 free() 將該指針傳遞回來時,我們只需要倒退幾個內存字節就可以再次找到這個結構。


  在討論分配內存之前,我們將先討論釋放,因為它更簡單。為了釋放內存,我們必須要做的惟一一件事情就是,獲得我們給出的指針,回退 sizeof(struct mem_control_block) 個字節,并將其標記為可用的。這里是對應的代碼:


  清單 4. 解除分配函數
  void free(void *firstbyte) {
  struct mem_control_block *mcb;
  /* Backup from the given pointer to find the
  * mem_control_block
  */
  mcb = firstbyte - sizeof(struct mem_control_block);
  /* Mark the block as being available */
  mcb->is_available = 1;
  /* That's It!  We're done. */
  return;
  }


  如您所見,在這個分配程序中,內存的釋放使用了一個非常簡單的機制,在固定時間內完成內存釋放。分配內存稍微困難一些。以下是該算法的略述:


  清單 5. 主分配程序的偽代碼
  1. If our allocator has not been initialized, initialize it.
  2. Add sizeof(struct mem_control_block) to the size requested.
  3. start at managed_memory_start
    4. Are we at last_valid address?
  5. If we are:
  A. We didn't find any existing space that was&nbs

下一篇: PLC、DCS、FCS三大控

上一篇: 索爾維全系列Solef?PV

中文字幕第二一区_久久久久在线视频_精品国产自在现线看久久_亚洲精品一区二区三区电影网

      亚洲午夜在线| 亚洲黄色影院| 久久久久久综合| 亚洲国产精品欧美一二99| 欧美三级视频在线| 久久久亚洲国产美女国产盗摄| 亚洲理伦电影| 激情小说另类小说亚洲欧美| 国产精品v日韩精品v欧美精品网站| 久久久久国产精品一区二区| 一区二区三区波多野结衣在线观看| 韩国av一区| 国产欧美日韩一区二区三区| 欧美午夜大胆人体| 欧美激情视频一区二区三区不卡| 久久精品国产免费看久久精品| 中日韩男男gay无套| 亚洲免费大片| 91久久精品一区二区别| 黄色影院成人| 国产日韩在线不卡| 国产精品卡一卡二| 国产精品magnet| 欧美日韩国产在线| 欧美日韩一区在线视频| 欧美日本一区二区三区| 欧美高清在线视频| 欧美福利一区| 欧美激情四色 | 国产精品一级| 国产精品久久久久久模特| 欧美日韩国产一区精品一区| 欧美黑人多人双交| 欧美激情中文字幕一区二区| 欧美77777| 欧美日韩二区三区| 国产精品v一区二区三区| 欧美丝袜一区二区三区| 国产精品美女久久久久久久| 国产精品一区二区在线观看不卡 | 亚洲午夜羞羞片| 亚洲综合欧美日韩| 欧美一区亚洲一区| 久久免费偷拍视频| 欧美激情综合色| 国产精品大片免费观看| 国产精品一区二区久激情瑜伽| 国产日本亚洲高清| 亚洲黄一区二区| 在线午夜精品| 久久精品国产96久久久香蕉| 欧美aaa级| 国产精品二区二区三区| 狠狠色狠狠色综合人人| 日韩亚洲欧美高清| 久久久999成人| 欧美精品导航| 国语自产精品视频在线看一大j8| 91久久黄色| 欧美在线高清视频| 欧美三级第一页| 国内成人精品一区| 一区二区三区视频在线观看| 久久精品网址| 欧美日韩亚洲视频一区| 黄色成人片子| 欧美一区二区三区久久精品| 欧美成人性生活| 国产手机视频一区二区| 一本色道久久综合亚洲精品不| 欧美专区第一页| 欧美日韩在线观看一区二区三区| 国内精品久久久久影院 日本资源| 亚洲欧洲一区二区三区久久| 欧美一区三区三区高中清蜜桃| 欧美区视频在线观看| 激情综合自拍| 久久福利影视| 国产日韩欧美一区二区| 亚洲性感美女99在线| 欧美日本高清一区| 在线观看一区视频| 久久久久久久91| 国产午夜精品一区二区三区欧美 | 亚洲一级免费视频| 欧美日韩成人综合| 亚洲精品在线观| 女女同性精品视频| 亚洲激情亚洲| 欧美激情二区三区| 亚洲国产片色| 欧美韩日一区| 亚洲精品四区| 欧美日韩视频在线| 亚洲午夜未删减在线观看| 欧美日韩国产美| 亚洲天堂成人在线视频| 欧美吻胸吃奶大尺度电影| 亚洲香蕉网站| 国产精品免费看| 欧美专区亚洲专区| 在线播放日韩专区| 欧美一区二区视频在线观看| 国产日韩欧美精品一区| 久久精品99无色码中文字幕| 国内精品**久久毛片app| 久久久久久久久久久久久久一区| 激情综合五月天| 国产精品极品美女粉嫩高清在线| 国产一区二区| 老司机一区二区| 亚洲在线视频| 夜夜爽夜夜爽精品视频| 在线精品国产成人综合| 国产嫩草一区二区三区在线观看 | 亚洲精品一区二区三| 激情亚洲网站| 国产欧美日韩视频一区二区| 欧美日韩综合视频网址| 欧美激情国产日韩| 久久手机精品视频| 欧美亚洲一区二区在线观看| 亚洲午夜国产一区99re久久 | 欧美在线国产精品| 国产精品成人观看视频国产奇米| 午夜亚洲伦理| 亚洲精品五月天| 国产日本欧洲亚洲| 欧美激情91| 久久不射中文字幕| 亚洲精品三级| 狠狠色丁香久久婷婷综合丁香| 欧美成人免费一级人片100| 亚洲视频在线观看视频| 在线免费观看日本一区| 国产精品www色诱视频| 鲁大师成人一区二区三区| 亚洲天堂av高清| 亚洲国产精品一区二区第四页av | 好看的亚洲午夜视频在线| 欧美另类videos死尸| 久久久91精品| 亚洲欧美国产制服动漫| 99精品久久久| 亚洲国产精品电影在线观看| 国产亚洲精品成人av久久ww| 欧美日韩国产色综合一二三四| 久久蜜臀精品av| 欧美一区二区黄| 亚洲一区二区三区欧美| 一本色道久久88综合日韩精品 | 亚洲精品综合| 136国产福利精品导航网址| 国产伦精品一区二区三区视频孕妇| 欧美日韩国产在线一区| 免费在线国产精品| 美国成人毛片| 裸体素人女欧美日韩| 久久av二区| 久久不射中文字幕| 欧美一级大片在线观看| 香蕉久久夜色精品| 亚洲男女毛片无遮挡| 亚洲无线视频| 亚洲欧美欧美一区二区三区| 在线亚洲美日韩| 亚洲香蕉伊综合在人在线视看| 日韩午夜黄色| 亚洲永久免费| 欧美一区二区三区日韩视频| 欧美伊人精品成人久久综合97| 亚洲欧美日韩综合aⅴ视频| 亚洲视频免费看| 午夜精品免费| 久久精品一区二区| 免费中文日韩| 欧美激情日韩| 欧美日韩在线视频观看| 国产精品久久久一区二区| 国产欧美日本| 国产午夜精品在线| 在线观看亚洲一区| 亚洲精品免费看| 亚洲午夜成aⅴ人片| 久久精品盗摄| 欧美黄色影院| 国产精品日本一区二区 | 欧美在线一区二区三区| 久久久久国产精品人| 欧美激情亚洲国产| 欧美视频在线不卡| 国产午夜精品视频| 最新中文字幕一区二区三区| 亚洲作爱视频| 久久人体大胆视频| 欧美午夜片在线观看| 国产主播一区二区| 9l视频自拍蝌蚪9l视频成人| 亚洲欧美国产三级| 欧美高清不卡在线|