亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C語言中動態(tài)內(nèi)存管理初學(xué)者容易犯的6個錯誤分享

 更新時間:2023年04月02日 10:37:34   作者:努力學(xué)習(xí)游泳的魚  
本篇文章主要介紹了初學(xué)者使用C語言中動態(tài)內(nèi)存管理的4個函數(shù)時最容易犯的6個錯誤,以及如何避免這些錯誤,文中的示例代碼講解詳細,感興趣的可以了解一下

我在這篇文章中,詳細講解了C語言中的4個動態(tài)內(nèi)存管理函數(shù)。本篇文章,我會講解初學(xué)者使用這4個函數(shù)時最容易犯的6個錯誤,以及如何避免這些錯誤。這6個容易犯的錯誤分別是:

  • 對NULL指針的解引用操作。
  • 對動態(tài)內(nèi)存的越界訪問。
  • 忘記free。
  • 對同一塊空間free兩次。
  • free動態(tài)內(nèi)存的一部分。
  • free非動態(tài)開辟的內(nèi)存。

我希望,當(dāng)你閱讀完本篇文章后,不要犯類似的錯誤。

1.對NULL指針的解引用操作

當(dāng)你malloc一塊空間時,是有可能開辟失敗的。一旦失敗,malloc會返回NULL指針。如果不判斷malloc的返回值,就直接使用malloc返回的指針,有可能導(dǎo)致對NULL指針的解引用操作。例如:

int* p = (int*)malloc(10 * sizeof(int));
for (int i = 0; i < 10; i++)
{
    p[i] = i + 1;
}

由于malloc可能返回NULL指針,一旦p為NULL,對其解引用是非常危險的!

解決方法:每次使用malloc, calloc, realloc等函數(shù)時,一定要判斷返回值是否為NULL。

int* p = (int*)malloc(10 * sizeof(int));
if (p == NULL)
{
    // 錯誤處理
    perror("malloc");
    exit(-1);
}
// 此時p一定不為NULL
for (int i = 0; i < 10; i++)
{
    p[i] = i + 1;
}

2.對動態(tài)內(nèi)存的越界訪問

假設(shè)你使用malloc申請了40個字節(jié)的空間,一定要記住這塊空間的大小,不能越界訪問。比如:

int* p = (int*)malloc(10 * sizeof(int));
if (p == NULL)
{
    // 錯誤處理
    perror("malloc");
    exit(-1);
}
for (int i = 0; i <= 10; i++)
{
    p[i] = i + 1;
}

上面的代碼中,當(dāng)i==10時,p[i]等價于*(p+10),已經(jīng)超出了申請的40個字節(jié)的空間,這是非常危險的!

解決方法:無論如何,在用指針訪問內(nèi)存時,一定要觀察其是否越界!比如上面的代碼,只能訪問p[0]~p[9]的空間。

3.忘記free

如果你使用malloc等函數(shù),開辟了空間,但是確沒有free,就會導(dǎo)致內(nèi)存泄漏!對于程序員來說,這種情況是非常不舒服的,一定要避免。

解決方法:對于每一塊動態(tài)內(nèi)存開辟的空間,使用完后都要free。比如:

int* p = (int*)malloc(10 * sizeof(int));
if (p == NULL)
{
    perror("malloc");
    exit(-1);
}
// 使用
// ...
free(p);
p = NULL;

4.對同一塊空間free兩次

如果已經(jīng)free過一塊空間了,如果再free一次,那不多此一舉嗎!不僅如此,如果第一次free之后沒有把這個指針置為NULL,第二次free的時候,這個指針是一個野指針,是非常危險的!

int* p = (int*)malloc(10 * sizeof(int));
if (p == NULL)
{
    perror("malloc");
    exit(-1);
}
// 使用
// ...
free(p);
// ...
free(p);

解決方法:你free一次就行了,干啥要free兩次呀!

值得說明的是,由于free(NULL);時,free函數(shù)啥也不干,所以下面的代碼是不會有問題的,但也不建議這么寫(有點吃飽了撐著的感覺)。

// ...
free(p);
p = NULL;
free(p);

5.free動態(tài)內(nèi)存的一部分

注意,free一個指針的時候,這個指針必須指向動態(tài)內(nèi)存的起始位置!比如下面的代碼中,如果這個指針已經(jīng)不指向起始位置了,free的時候也是非常危險的。

int* p = (int*)malloc(10 * sizeof(int));
if (p == NULL)
{
    perror("malloc");
    exit(-1);
}
// ...
p += 5;
// ...
free(p);
p = NULL;

由于在malloc之后,free之前,指針p已經(jīng)不指向動態(tài)內(nèi)存的起始位置了,此時再free掉p就會出問題。

解決方法:由于free的時候需要知道動態(tài)內(nèi)存的起始地址,在使用這塊內(nèi)存的時候不建議改變p的指向。除此之外,如果使用realloc擴容,一定要更新p,時刻讓p指向動態(tài)內(nèi)存的起始地址,方便free釋放。

int* p = (int*)malloc(10 * sizeof(int));
if (p == NULL)
{
    perror("malloc");
    exit(-1);
}
// ...
// 使用時時刻讓p指向動態(tài)內(nèi)存的起始位置!
int* tmp = (int*)realloc(p, 20 * sizeof(int));
if (tmp == NULL)
{
    free(p);
    p = NULL;
    perror("realloc");
    exit(-1);
}
else
{
    p = tmp;
}
// ...
free(p);
p = NULL;

6.free非動態(tài)開辟的內(nèi)存

free是用來釋放動態(tài)開辟的內(nèi)存的。所以,如果這塊內(nèi)存空間不是用malloc, calloc, realloc動態(tài)開辟的,就別free啦。

int arr[10] = {0};
// ...
int a = 0;
int* pa = &a;
// ...
free(arr);
arr = NULL;
free(pa);
pa = NULL;

解決方法:不要寫出這樣的代碼,free的時候得看清楚,這塊空間到底是不是動態(tài)開辟的空間,時刻保持頭腦清醒。

總結(jié)

C語言動態(tài)內(nèi)存管理時,容易犯的6個錯誤及解決方法:

1.對NULL指針的解引用操作。這是由于malloc等函數(shù)有可能返回NULL,所以需要檢查返回值。

2.對動態(tài)內(nèi)存的越界訪問。時時刻刻記住,這塊空間究竟有多大,不要越界了。

3.忘記free。別忘記就行。

4.對同一塊空間free兩次。free一次就行啦,再free一次是多此一舉。

5.free動態(tài)內(nèi)存的一部分。時時刻刻讓一個指針記住這塊動態(tài)內(nèi)存的起始地址。

6.free非動態(tài)開辟的內(nèi)存。保持頭腦清醒,只有malloc, calloc, realloc出來的空間才需要free。

到此這篇關(guān)于C語言中動態(tài)內(nèi)存管理初學(xué)者容易犯的6個錯誤分享的文章就介紹到這了,更多相關(guān)C語言動態(tài)內(nèi)存管理內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 解析C#中不一樣的大小寫轉(zhuǎn)換

    解析C#中不一樣的大小寫轉(zhuǎn)換

    本篇文章是對C#中大小寫轉(zhuǎn)換的方法進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • C語言中break與continue的用法和區(qū)別詳解

    C語言中break與continue的用法和區(qū)別詳解

    當(dāng)我們使用while或for循環(huán)時,如果想提前結(jié)束循環(huán)(在不滿足結(jié)束條件的情況下結(jié)束循環(huán)),可以使用break或continue關(guān)鍵字,這篇文章主要給大家介紹了關(guān)于C語言中break與continue的用法和區(qū)別的相關(guān)資料,需要的朋友可以參考下
    2021-10-10
  • C語言中讀寫交替時出現(xiàn)的問題分析

    C語言中讀寫交替時出現(xiàn)的問題分析

    讀寫命令交替,一定要使用fseek重新定位,否則出現(xiàn)輸入顯示混亂,這篇文章主要介紹了C語言中讀寫交替時出現(xiàn)的問題分析,需要的朋友可以參考下
    2022-12-12
  • 基于C++浮點數(shù)(float、double)類型數(shù)據(jù)比較與轉(zhuǎn)換的詳解

    基于C++浮點數(shù)(float、double)類型數(shù)據(jù)比較與轉(zhuǎn)換的詳解

    本篇文章是對C++中浮點數(shù)(float、double)類型數(shù)據(jù)比較與轉(zhuǎn)換進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • C++中string轉(zhuǎn)換為char*類型返回后亂碼問題解決

    C++中string轉(zhuǎn)換為char*類型返回后亂碼問題解決

    這篇文章主要介紹了C++中string轉(zhuǎn)換為char*類型返回后亂碼問題解決,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • 用C++實現(xiàn)一個鏈式棧的實例代碼

    用C++實現(xiàn)一個鏈式棧的實例代碼

    本篇文章是對使用C++實現(xiàn)一個鏈式棧的代碼進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • C++中各種可調(diào)用對象深入講解

    C++中各種可調(diào)用對象深入講解

    這篇文章主要給大家介紹了關(guān)于C++中各種可調(diào)用對象的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-02-02
  • C語言開發(fā)簡易版掃雷小游戲

    C語言開發(fā)簡易版掃雷小游戲

    本文給大家分享的是一個使用C語言開發(fā)的命令行下的簡易版掃雷小游戲,本身沒有什么太多的技術(shù)含量,只不過是筆者的處女作,所以還是推薦給大家,希望對大家學(xué)習(xí)C能夠有所幫助。
    2015-12-12
  • C++ 前置聲明詳解及實例

    C++ 前置聲明詳解及實例

    這篇文章主要介紹了C++ 前置聲明詳解及實例的相關(guān)資料,需要的朋友可以參考下
    2017-06-06
  • C++ 關(guān)鍵字 inline詳細介紹

    C++ 關(guān)鍵字 inline詳細介紹

    這篇文章主要介紹了C++ 關(guān)鍵字 inline,有需要的朋友可以參考一下
    2014-01-01

最新評論