二级指针内存模型训练实例

//
//  main.c
//  二级指针内存模型训练实例
//
//  Created by Eric on 16/7/3.
//  Copyright © 2016年 Eric. All rights reserved.
//

#include 
#include "stdlib.h"
#include "string.h"

int sortAllocMemory(char ** myArray1,int myArray1Num,char (*myArray2)[10],int myArray2Num,char ***sortArray,int *numCount){
    int  ret = 0;
    int num = myArray1Num+myArray2Num;
    char **array3 = (char **)malloc(sizeof(char*)*(num));
    
    /**
     *  先将数据 拷贝进 array3
     */
    
    int i = 0,j = 0;
    for (; i< myArray1Num; i++) {
        //先分配内存
        size_t len = strlen(myArray1[i])+1;//用来计算指定的字符串s 的长度,不包括结束字符"\0"。这里要加1
        array3[i] = (char*)malloc(sizeof(char)*len);
        
        //进行拷贝
        strcpy(array3[i], myArray1[i]);
    }
    for(;j%s",myArray1[j]);
        strcpy(array3[i+j], myArray2[j]);
    }
    
    /**
     *  全部进行排序
     */
    
    char *tmp = NULL; //定义一个辅助指针变量
    for (int i = 0; i0) {
                tmp = array3[i];
                array3[i] = array3[j];
                array3[j] = tmp;
            }
        }
    }
    
    *sortArray = array3;
    *numCount = num;

    return ret;
}

//释放三级指针 再次打印 会报错
void sortfree(char ***p,int num){
    
    char **myArray = *p;//转换成二级指针
    if (p == NULL) {
        return;
    }
    for(int i = 0; i < num;i++ ){
        free(myArray[i]);
    }
    free(myArray);
    *p = NULL; //间接赋值是指针存在的最大意义
}
//释放二级指针 再次打印 是乱码
void sortfree2(char **p,int num){

    if (p == NULL) {
        return;
    }
    for (int i = 0; i%p\n",arr3);
    
    sortAllocMemory(arr1, arrNum, arr2, arrNum2, &arr3,&count);
    printf("count ----->%d\n",count);
    printArray(arr3, count);
    sortfree(&arr3, count);
   // printArray(arr3, count);
    
    
    
    
    return 0;
}

你可能感兴趣的:(二级指针内存模型训练实例)