C語言之動態(tài)分配內(nèi)存空間

動態(tài)分配內(nèi)存

  • 為什么需要動態(tài)分配內(nèi)存:
    1.存儲的數(shù)據(jù) 需要延長生命周期
    2.一個指針變量需要存儲數(shù)據(jù),變量本身只能存地址,不能存數(shù)據(jù),需要分配內(nèi)存空間來存儲數(shù)據(jù)
#include <stdio.h>
#include <stdlib.h>


int main(){
    //char name[100] = {};數(shù)組確定大小是為了分配內(nèi)存空間 
    
    //如果使用指針變量接收數(shù)據(jù)
    //必須先為這個指針變量分配一片指向的內(nèi)存空間
    //有內(nèi)存空間 才能存數(shù)據(jù) 
    
    //使用malloc必須導入頭文件stdlib.h 
    //使用malloc (memory alloc)申請內(nèi)存空間 
    char *name ;
    name = (char *)malloc(10*sizeof(char));
    if(name == NULL){
        // 申請內(nèi)存失敗 
        exit(EXIT_FAILURE); 
    }
    scanf("%s", name);
    printf("%s\n",name); 
    
    //使用realloc動態(tài)改變已經(jīng)分配內(nèi)存的大小 
    //增加或者減少 
    name = (char *)realloc(name, 20*sizeof(char));
    //判斷重新分配是否成功 
    if(name == NULL){
        //退出之前必須將之前分配的內(nèi)存釋放掉
        free(name); 
        exit(EXIT_FAILURE);//表示程序直接退出,如果此次分配不成功直接結(jié)束
        //會導致之前malloc分配的內(nèi)存泄漏,所以為了防止泄漏,在程序結(jié)束之前應(yīng)該釋放掉內(nèi)存 
    }
    
    //使用完畢必須自己手動釋放內(nèi)存
    free(name); 
    return 0;
}

小實戰(zhàn)之錄入個人名單

合理使用內(nèi)存
請輸入姓名:jack
是否繼續(xù)(y/n)?:y
請輸入姓名:jackson
是否繼續(xù)(y/n)?:n
錄入2個人的信息
jack
jackson

#include <stdio.h>
#include <stdlib.h>
#include <stdbool.h>

//從終端接收字符串 返回這個字符串的首地址
char *inputName(){
    //1.定義一個指針變量 指向字符串的首地址
    char *pName = NULL;
    //2.接收輸入
    int i = 0;
    //3.提示操作
    printf("請輸入人名:");
    while (1) {
        //接收一個字符
        char c = getchar();
        //判斷這個字符是不是\n
        if (c == '\n') {
            //輸入結(jié)束
            break;
        }
        //判斷是不是第一個字符
        if(i == 0){
            //使用malloc分配內(nèi)存
            pName = (char *)malloc(1*sizeof(char));
            //判斷是否分配成功
            if(pName == NULL){
                exit(EXIT_FAILURE);
            }
            pName[0] = c;
        }else{
            //使用realloc在之前的基礎(chǔ)上加一個
            pName = (char *)realloc(pName, (i+1)*sizeof(char));
            //判斷是否分配成功
            if(pName == NULL){
                exit(EXIT_FAILURE);
            }
            pName[i] = c;
        }
        
        i++;
    }
    //將當前的字符串首地址返回
    return pName;
}

//是否繼續(xù)
bool isContinue(){
    printf("是否繼續(xù)(y/n)?:");
    while (1) {
        char c = getchar();
        getchar();
        if (c == 'y'){
            return true;
        }else if(c == 'n'){
            return false;
        }else{
            printf("輸入格式不對,請重新輸入:");
        }
    }
}
//初始化整個數(shù)組
char **initNames(int *pNum){
    //1.定義指針變量指向每個名字的首地址的內(nèi)存
    char **pHead = NULL;
    
    //2.記錄元素個數(shù)
    int i = 0;
    while (1) {
        //判斷是不是第一個
        //第一個使用malloc分配內(nèi)存
        if (i == 0) {
            pHead = (char **)malloc(1*sizeof(char *));
            if (pHead == NULL) {
                exit(EXIT_FAILURE);
            }
            
            //輸入人名 將地址放到pHead對應(yīng)位置
            pHead[0] = inputName();
        }else{
            //使用realloc重新再增加一個元素
            pHead = (char **)realloc(pHead, (i+1)*sizeof(char *));
            if (pHead == NULL) {
                exit(EXIT_FAILURE);
            }
            //輸入人名 將地址放到pHead對應(yīng)位置
            pHead[i] = inputName();
        }
        
        i++;
        
        //是否繼續(xù)
        bool result = isContinue();
        if (result == false) {
            break;
        }
    }
    
    *pNum = i;
    return pHead;
}

void show(char **pHead, int num){
    printf("輸入%d個名字:\n",num);
    for (int i = 0; i < num; i++) {
        printf("%s\n",pHead[i]);
    }
    printf("\n");
}

int main(int argc, const char * argv[]) {
    char **pHead = NULL;
    int count = 0;
    pHead = initNames(&count);
    show(pHead, count);
    return 0;
}

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容