溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

三級(jí)指針的應(yīng)用場(chǎng)景

發(fā)布時(shí)間:2020-06-28 07:17:53 來源:網(wǎng)絡(luò) 閱讀:2348 作者:匯天下豪杰 欄目:編程語言

1、問題:將指針數(shù)組和二維數(shù)組中的字符串存放到第三個(gè)指針?biāo)赶虻膬?nèi)存空間中,并進(jìn)行排序(默認(rèn)升序)輸出,必須通過函數(shù)來完成。

(1)、代碼如下:
#include<stdio.h>
#include<string.h>
#include<malloc.h>

void destorySpace_2(char ***p3, int len3);
void destorySpace_1(char **p3, int len3);
int sort(char **myp1, int len1, char (*myp2)[30], int len2, char ***myp3, int *len3);

int sort(char **myp1, int len1, char (*myp2)[30], int len2, char ***myp3, int *len3){
    int len;
    int i;
    int j;
    char **p3 = NULL;
    int temLen;
    char *tmp1;

    len = len1 + len2;
    p3 = (char **)malloc(sizeof(char *) * len);

    //先將第一個(gè)指針數(shù)組的內(nèi)容拷貝到p3所指向的空間中
    for(i = 0; i < len1; i++){
        temLen = strlen(myp1[i])+1;
        p3[i] = (char *)malloc(sizeof(char) * temLen);
        strcpy(p3[i], myp1[i]);
    }
    //先將第二個(gè)二維數(shù)組的內(nèi)容拷貝到p3所指向的空間中
    for(j = 0; j < len2; j++, i++){
        temLen = strlen(myp2[j])+1;
        p3[i] = (char *)malloc(sizeof(char) * temLen);
        strcpy(p3[i], myp2[j]);
    }

    //最后對(duì)p3所指向的空間的字符串在進(jìn)行排序;
    for(i = 0; i < len; i++){
        for(j = i+1; j < len; j++){
            if(strcmp(p3[i], p3[j]) > 0){
                tmp1 = p3[i];
                p3[i] = p3[j];
                p3[j] = tmp1;
            }
        }
    }

    *myp3 = p3;
    *len3 = len;

    return 0;
}   
//銷毀p3所指向空間的第一種方法,自己必須在調(diào)用下面對(duì)p3 = NULL;
void destorySpace_1(char **p3, int len3){
    int i;

    if(p3 != NULL){
        for(i = 0; i < len3; i++){
            if(p3[i] != NULL){
                free(p3[i]);
            }
        }
        free(p3);
    }
} 
//銷毀p3所指向空間的第二種方法
void destorySpace_2(char ***p3, int len3){
    int i;
    char **p;

    if(p3 == NULL){
        return;
    }
    p = *p3;
    if(p != NULL){
        for(i = 0; i < len3; i++){
            if(p[i] != NULL){
                free(p[i]);
            }
        }

        free(p);
        *p3 = NULL;
    }
}
int main(void){
    char *p1[] = {"aaaaa", "bbbbb", "ccccc", "eeeeeee"};
    char buf1[][30] = {"fffff", "kkkkkkk"};
    char **p3;
    int len1;
    int len2;
    int len3;
    int ret;
    int i;

    len1 = sizeof(p1)/sizeof(p1[0]);
    len2 = sizeof(buf1)/sizeof(buf1[0]);

    ret = sort(p1, len1, buf1, len2, &p3, &len3);
    if(ret != 0){
        printf("sort() err\n");
        return ret;
    }

    for(i = 0; i < len3; i++){
        printf("%s\n", p3[i]);
    }
   //destorySpace_2(&p3, len3);
    destorySpace_1(p3, len3);
    p3 = NULL;

    return 0;
}

(2)、運(yùn)行結(jié)果:

三級(jí)指針的應(yīng)用場(chǎng)景

(3)、模型分析

  思想:因?yàn)橐煤瘮?shù)完成,對(duì)二維數(shù)組和指針數(shù)組中的字符串先進(jìn)行存放到p3所指向的空間中,就必須的使用三級(jí)指針來接收了,然后在對(duì)其所指向的空間進(jìn)行排序!

  在進(jìn)行空間的釋放時(shí),要是在函數(shù)內(nèi)部避免野指針問題,就必須的用三級(jí)指針來接收了!

  在進(jìn)行空間的釋放時(shí),要是用二級(jí)指針來接收的話,則自己必須在調(diào)用的下面對(duì)其進(jìn)行賦空,避免野指針的出現(xiàn),原因:2個(gè)指針空間的值沒有半毛錢的關(guān)系(它們之間僅僅是形參、實(shí)參的對(duì)應(yīng)關(guān)系)?。?!

拋出問題的代碼:

//函數(shù)調(diào)用
destorySpace(char **p3){
    ......
    p3 = NULL;
}
//主函數(shù)
int main(void){
    char **p3 = NULL;
    ...
    destorySpace(p3);
}

模型如下:
三級(jí)指針的應(yīng)用場(chǎng)景



向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI