C语言二级指针的三种内存模型如何构成一个长尾词的?
- 内容介绍
- 文章标签
- 相关推荐
本文共计1309个文字,预计阅读时间需要6分钟。
二级指针相对于一级指针,显得更复杂,难以在指针和数组混合时处理。定义不同类型的二级指针,在使用时具有很大的区别。例如,一种内存模型char *arr[]={abc, de}。
二级指针相对于一级指针,显得更难,难在于指针和数组的混合,定义不同类型的二级指针,在使用的时候有着很大的区别
第一种内存模型char *arr[]
若有如下定义
char *arr[] = {"abc", "def", "ghi"};
这种模型为二级指针的第一种内存模型,在理解的时候应该这样理解:定义了一个指针数组(char * []),数组的每个元素都是一个地址。
在使用的时候,若要使用中间量操作元素,那么此时中间量应该定义为
char *tmp = NULL;
如果要打印这个数组,那么可以使用以下函数
int printAarray(char **pArray, int num) { int i = 0; if (pArray == NULL) { return -1; } for (i = 0; i < num; i++) { printf("%s \n", pArray[i]); } return 0; }
第二种内存模型char arr[][]
若有如下定义
char arr[3][5] = {"abc", "def", "ghi"};
这种模型为二级指针的第二种内存模型,在理解的时候应该这样理解:定义了一个二维数组,有3个(5个char)空间的存储变量。
本文共计1309个文字,预计阅读时间需要6分钟。
二级指针相对于一级指针,显得更复杂,难以在指针和数组混合时处理。定义不同类型的二级指针,在使用时具有很大的区别。例如,一种内存模型char *arr[]={abc, de}。
二级指针相对于一级指针,显得更难,难在于指针和数组的混合,定义不同类型的二级指针,在使用的时候有着很大的区别
第一种内存模型char *arr[]
若有如下定义
char *arr[] = {"abc", "def", "ghi"};
这种模型为二级指针的第一种内存模型,在理解的时候应该这样理解:定义了一个指针数组(char * []),数组的每个元素都是一个地址。
在使用的时候,若要使用中间量操作元素,那么此时中间量应该定义为
char *tmp = NULL;
如果要打印这个数组,那么可以使用以下函数
int printAarray(char **pArray, int num) { int i = 0; if (pArray == NULL) { return -1; } for (i = 0; i < num; i++) { printf("%s \n", pArray[i]); } return 0; }
第二种内存模型char arr[][]
若有如下定义
char arr[3][5] = {"abc", "def", "ghi"};
这种模型为二级指针的第二种内存模型,在理解的时候应该这样理解:定义了一个二维数组,有3个(5个char)空间的存储变量。

