0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

動態(tài)內(nèi)存分配舉例,以及動態(tài)數(shù)組的構(gòu)造

Q4MP_gh_c472c21 ? 來源:未知 ? 作者:李倩 ? 2018-07-10 16:41 ? 次閱讀

一:傳統(tǒng)數(shù)組(靜態(tài)數(shù)組)的缺點(diǎn)

1:數(shù)組的長度必須事先指定,并且是常整數(shù),不能是變量 int a[5];2:傳統(tǒng)數(shù)組程序員無法由程序員釋放,只能由系統(tǒng)釋放。(并且只能在數(shù)組所在函數(shù)結(jié)束才能釋放)3:數(shù)組的長度在函數(shù)運(yùn)行期間不能動態(tài)的擴(kuò)充和縮小4:A函數(shù)定義的傳統(tǒng)數(shù)組,在A函數(shù)結(jié)束時(shí),在B函數(shù)中是不能使用的,因?yàn)橐呀?jīng)釋放。也就是傳統(tǒng)數(shù)組不能跨函數(shù)。

區(qū)分:靜態(tài)存儲與內(nèi)存的靜態(tài)開辟

二:為什么要?jiǎng)討B(tài)分配內(nèi)存

用來解決傳統(tǒng)數(shù)組的四個(gè)缺陷

三:動態(tài)內(nèi)存分配舉例,以及動態(tài)數(shù)組的構(gòu)造

方式:malloc函數(shù),在堆開辟空間

1:malloc是由程序員在堆棧動態(tài)開辟空間2:返回值開辟空間的首地址,但是類型是void *,需要強(qiáng)制類型轉(zhuǎn)換3:分配的內(nèi)存空間應(yīng)該能整除類型所占的字節(jié)數(shù)4:包含頭文件malloc.h5:只能用free(p)來釋放p所指向的動態(tài)開辟的內(nèi)存空間。6:對動態(tài)內(nèi)存空間的操作,用*p來操作。7:可以用多個(gè)指針指向這個(gè)動態(tài)空間8:當(dāng)有多個(gè)指針只向這個(gè)動態(tài)空間時(shí),只能用free一個(gè)指針,多次重復(fù)釋放要被報(bào)錯(cuò)9:可以將動態(tài)開辟的的內(nèi)存指針作為函數(shù)參數(shù)

問題:p的分配類型是動態(tài)的還是靜態(tài)的?當(dāng)調(diào)用free(p)后,p的內(nèi)存空間會被釋放么?例子:動態(tài)構(gòu)建一個(gè)一維數(shù)組:

動態(tài)擴(kuò)充數(shù)組的長度,也就是在程序運(yùn)行時(shí)動態(tài)擴(kuò)充:realloc(首地址,總共字節(jié)數(shù))

作用:將原來動態(tài)開辟的動態(tài)內(nèi)存重新開辟一個(gè)字節(jié)數(shù),如果這個(gè)數(shù)比以前的大,前面的數(shù)據(jù)保存。如果比原來的小,保留前面的數(shù)據(jù)。

注意:擴(kuò)充或者縮放的內(nèi)存單元是新開辟的內(nèi)存單元。這個(gè)過程中有值的拷貝過程。返回值是新開辟的地址空間首地址。

四:靜態(tài)內(nèi)存和動態(tài)內(nèi)存的比較

靜態(tài)開辟的內(nèi)存:在棧中開辟,由編譯器分配,由系統(tǒng)自動釋放動態(tài)開辟的內(nèi)存:在堆中開辟,由程序員開辟,由程序員自動釋放。

五:跨函數(shù)使用內(nèi)存的問題

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • C語言
    +關(guān)注

    關(guān)注

    180

    文章

    7594

    瀏覽量

    135855
  • 函數(shù)
    +關(guān)注

    關(guān)注

    3

    文章

    4277

    瀏覽量

    62323
  • 數(shù)組
    +關(guān)注

    關(guān)注

    1

    文章

    412

    瀏覽量

    25880

原文標(biāo)題:C語言動態(tài)內(nèi)存分配基礎(chǔ)知識詳解

文章出處:【微信號:gh_c472c2199c88,微信公眾號:嵌入式微處理器】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    動態(tài)內(nèi)存管理模塊的設(shè)計(jì)原理與實(shí)現(xiàn)

    以及被釋放的時(shí)候,F(xiàn)ense又從st_Head中刪除之,檢查st_Head中的節(jié)點(diǎn)即可得到未被釋放的本節(jié)點(diǎn)的數(shù)值校驗(yàn)和等。Fense將每一個(gè)分配動態(tài)內(nèi)存塊插入到鏈表st_Head中;當(dāng)此內(nèi)存
    的頭像 發(fā)表于 06-30 08:05 ?2317次閱讀
    <b class='flag-5'>動態(tài)內(nèi)存</b>管理模塊的設(shè)計(jì)原理與實(shí)現(xiàn)

    C語言知識總結(jié):動態(tài)內(nèi)存分配

    動態(tài)內(nèi)存分配就 是指在程序執(zhí)行的過程中動態(tài)分配或者回收存儲空間的分配內(nèi)存的方法。
    發(fā)表于 10-24 15:52 ?830次閱讀

    C語言程序設(shè)計(jì)中動態(tài)內(nèi)存分配如何實(shí)現(xiàn)

    C語言程序設(shè)計(jì)中,動態(tài)內(nèi)存分配如何實(shí)現(xiàn),需要注意哪些問題?
    發(fā)表于 09-28 16:53 ?1261次閱讀

    請問CCS下怎么使用malloc之類動態(tài)內(nèi)存函數(shù)?

    的采樣點(diǎn)數(shù)不確定,即電壓采樣值個(gè)數(shù)不確定,從而存放電壓采樣值的數(shù)組大小不能事先確定,需要根據(jù)條件判斷,動態(tài)確定數(shù)組的大小。所以,現(xiàn)在我打算使用動態(tài)內(nèi)存
    發(fā)表于 05-23 16:31

    內(nèi)存動態(tài)內(nèi)存分配實(shí)現(xiàn)

    第27章 STM32H7的TCM,SRAM等五塊內(nèi)存動態(tài)內(nèi)存分配實(shí)現(xiàn)本章教程為大家分享一種DTCM,SRAM1,SRAM2,SRAM3和SRAM4可以獨(dú)立管理的動態(tài)內(nèi)存管理方案,在實(shí)
    發(fā)表于 08-03 07:14

    如何在單片機(jī)上也可正常使用動態(tài)內(nèi)存分配

    51單片機(jī)內(nèi)存動態(tài)分配序言最近玩51單片機(jī)碰到一個(gè)問題,51中malloc函數(shù)并不能像在PC上一樣正常運(yùn)行,這涉及到了內(nèi)存池的概念。下面就來演示一下如何在單片機(jī)上也可正常使用動態(tài)內(nèi)存
    發(fā)表于 11-19 07:36

    嵌入式C語言動態(tài)內(nèi)存分配

    動態(tài)內(nèi)存分配:1、malloc、memset、free在日常寫代碼時(shí)需要注意以下幾點(diǎn):malloc分配內(nèi)存時(shí),需要 if語句 判斷malloc是否成功
    發(fā)表于 12-14 06:37

    請問使用動態(tài)內(nèi)存分配安全嗎?

    想在C語言程序員之間開始一個(gè)激烈的,或者說有爭議的討論很簡單,只需要問:“使用動態(tài)內(nèi)存分配安全嗎?”使用動態(tài)內(nèi)存分配安全嗎?在C語言程序開發(fā)中,動態(tài)
    發(fā)表于 12-15 06:10

    使用動態(tài)內(nèi)存分配安全嗎

    [導(dǎo)讀]想在C語言程序員之間開始一個(gè)激烈的,或者說有爭議的討論很簡單,只需要問:“使用動態(tài)內(nèi)存分配安全嗎?”想在C語言程序員之間開始一個(gè)激烈的,或者說有爭議的討論很簡單,只需要問:“使用動態(tài)內(nèi)存
    發(fā)表于 12-15 07:44

    動態(tài)內(nèi)存分配是什么意思

    所謂動態(tài)內(nèi)存分配(Dynamic Memory Allocation)就是指在程序執(zhí)行的過程中動態(tài)分配或者回收存儲空間的分配
    發(fā)表于 12-17 08:17

    RTThread的動態(tài)內(nèi)存空間該如何去分配

    結(jié)束地址劃分作為動態(tài)內(nèi)存,而NANO版本好像是開辟了一個(gè)靜態(tài)數(shù)組,這時(shí)候的動態(tài)內(nèi)存劃分位置就是位于BSS段2、使用malloc等系統(tǒng)函數(shù)分配到的內(nèi)存
    發(fā)表于 08-31 14:34

    動態(tài)內(nèi)存錯(cuò)誤的靜態(tài)檢測

    內(nèi)存泄漏、空指針引用等動態(tài)內(nèi)存錯(cuò)誤在/,/LL等支持動態(tài)內(nèi)存操作的程序中普遍存在在程序中,動態(tài)內(nèi)存管理錯(cuò)誤是導(dǎo)致動態(tài)內(nèi)存錯(cuò)誤的根本原因
    發(fā)表于 06-10 16:29 ?52次下載
    <b class='flag-5'>動態(tài)內(nèi)存</b>錯(cuò)誤的靜態(tài)檢測

    嵌入式中需要用到動態(tài)內(nèi)存

    所謂動態(tài)內(nèi)存分配(Dynamic Memory Allocation)就是指在程序執(zhí)行的過程中動態(tài)分配或者回收存儲空間的分配
    的頭像 發(fā)表于 07-27 08:11 ?3029次閱讀

    靜、動態(tài)內(nèi)存的優(yōu)劣比較

    動態(tài)內(nèi)存分配不像數(shù)組等靜態(tài)內(nèi)存分配方法那樣需要預(yù)先分配存儲空間,而是由系統(tǒng)根據(jù)程序的需要即時(shí)
    的頭像 發(fā)表于 08-06 18:25 ?6564次閱讀

    嵌入式C語言中的動態(tài)內(nèi)存管理和動態(tài)內(nèi)存分配

    動態(tài)內(nèi)存管理同時(shí)還具有一個(gè)優(yōu)點(diǎn):當(dāng)程序在具有更多內(nèi)存的系統(tǒng)上需要處理更多數(shù)據(jù)時(shí),不需要重寫程序。
    發(fā)表于 08-15 17:16 ?2246次閱讀