C 指向指针的指针
指向指针的指针是一种多级间接寻址的形式,或者说是一个指针链。通常,一个指针包含一个变量的地址。当我们定义一个指向指针的指针时,第一个指针包含了第二个指针的地址,第二个指针指向包含实际值的位置。
 
一个指向指针的指针变量必须如下声明,即在变量名前放置两个星号。例如,下面声明了一个指向 int 类型指针的指针:
int **var;
当一个目标值被一个指针间接指向到另一个指针时,访问这个值需要使用两个星号运算符,如下面实例所示:

实例
#include <stdio.h>
 
int main ()
{
   int  V;
   int  *Pt1;
   int  **Pt2;
 
   V = 100;
 
   /* 获取 V 的地址 */
   Pt1 = &V;
 
   /* 使用运算符 & 获取 Pt1 的地址 */
   Pt2 = &Pt1;
 
   /* 使用 pptr 获取值 */
   printf("var = %d\n", V );
   printf("Pt1 = %p\n", Pt1 );
   printf("*Pt1 = %d\n", *Pt1 );
    printf("Pt2 = %p\n", Pt2 );
   printf("**Pt2 = %d\n", **Pt2);
 
   return 0;
}
当上面的代码被编译和执行时,它会产生下列结果:
var = 100 Pt1 = 0x7ffee2d5e8d8 *Pt1 = 100 Pt2 = 0x7ffee2d5e8d0 **Pt2 = 100
 
 
 C 指针
 C 指针 
       
菜鸟lean
135***6665@qq.co
指针更像是一个找地址开门取物品的操作。其中 * 就是这个动作重复的次数,ptr 是取东西的门牌号也就是地址值:
菜鸟lean
135***6665@qq.co
Zhiqian Chen
che***iqian2005@qq.com
int **arr也可以理解为一个二维数组的动态表示。它通常用于创建动态分配的二维数组,允许在运行时根据需要分配和管理内存。步骤如下:示例:
#include <stdio.h> #include <stdlib.h> int main() { int rows = 3, cols = 4; // Step 1: 分配行指针数组 int **arr = (int **)malloc(rows * sizeof(int *)); // Step 2: 为每一行分配内存 for (int i = 0; i < rows; i++) { arr[i] = (int *)malloc(cols * sizeof(int)); } // 填充数组 for (int i = 0; i < rows; i++) { for (int j = 0; j < cols; j++) { arr[i][j] = i * cols + j + 1; // 填充示例数据 } } // 打印数组 for (int i = 0; i < rows; i++) { for (int j = 0; j < cols; j++) { printf("%d ", arr[i][j]); } printf("\n"); } // 释放内存 for (int i = 0; i < rows; i++) { free(arr[i]); // 释放每一行的内存 } free(arr); // 释放行指针数组 return 0; }优点:
malloc动态分配内存,可根据需要调整数组的大小。注意:使用完动态分配的内存后,必须使用
free释放,以防止内存泄漏。Zhiqian Chen
che***iqian2005@qq.com