大话C语言:第35篇 二维指针

二维指针,本质上是一个指向指针的指针,它使得通过一个指针变量就能跳转访问多个内存地址成为可能。二维指针主要用于处理指针的数组或指向指针的指针,特别是在动态创建和操作二维数组时非常有用。语法格式:

cpp 复制代码
数据类型 **指针变量;

代码示例:

cpp 复制代码
#include <stdio.h>  
#include <stdlib.h> 

int main() {  
    // 定义一维指针数组,存储整数的指针  
    int *ptrArray[3];  
  
    // 为一维指针数组中的每个元素分配内存,并初始化整数值  
    for (int i = 0; i < 3; i++)
    {  
        ptrArray[i] = (int *)malloc(sizeof(int));  
        if (ptrArray[i] == NULL) 
        {  
            printf("内存分配");  
            
            return -1;
        }  
        
        *ptrArray[i] = i + 1; // 为每个指针指向的整数赋值  
    }  
  
    // 定义二维指针,并让它指向一维指针数组  
    int **twoDPtr = ptrArray;  
  
    // 使用二维指针访问一维指针数组中的元素  
    for (int i = 0; i < 3; i++) 
    {  
        printf("二维指针遍历一维指针,当前值是%d\n", *(twoDPtr[i]));  
    }  
  
    // 修改二维指针指向的值(即修改一维指针数组中的某个指针指向的整数) 
    // 修改ptrArray[1]指向的整数值为100  
    *(twoDPtr[1]) = 100; 
  
    // 再次打印一维指针数组中的值,验证修改  
    printf("修改之后:\n");  
    for (int i = 0; i < 3; i++) 
    {  
        printf("二维指针遍历一维指针,当前值是%d\n", *(twoDPtr[i]));  
    }   
  
    // 释放分配的内存  
    for (int i = 0; i < 3; i++) 
    {  
        free(ptrArray[i]);  
    }
  
    return 0;  
}

二维指针作为函数参数,代码示例:

cpp 复制代码
#include <stdio.h>  
#include <stdlib.h> 

// 函数原型声明,接收一个二维指针参数  
void modifyArray(int **array, int size);  
  
int main() 
{  
    // 整数指针数组
    int *array[3];   
  
    // 为指针数组中的每个元素分配内存,并初始化整数值  
    for (int i = 0; i < 3; i++) 
    {  
        array[i] = (int *)malloc(sizeof(int));  
        if (array[i] == NULL) {  
            perror("内存分配失败\n");  
            retrun -1;
        }  
        *array[i] = i; // 为每个指针指向的整数赋值  
    }  
  
    // 打印原始数组的值  
    printf("原始数组的值分别是:\n");  
    for (int i = 0; i < 3; i++) {  
        printf("%d ", *array[i]);  
    }  
    printf("\n");  
  
    // 调用函数修改数组中的值  
    modifyArray(array, 3);  
  
    // 打印修改后的数组的值  
    printf("修改后的数组值分别是:\n");  
    for (int i = 0; i < 3; i++) 
    {  
        printf("%d ", *array[i]);  
    }  
    printf("\n");  
  
    // 释放内存  
    for (int i = 0; i < 3; i++) 
    {  
        free(array[i]);  
    }  
  
    return 0;  
}  
  
// 函数定义,接收二维指针作为参数,并修改数组中的值  
void modifyArray(int **array, int size) 
{  
    for (int i = 0; i < size; i++) 
    {  
        // 将数组中的每个值乘以2 
        *array[i] *= 2;  
    }  
}
相关推荐
chen_mangoo6 小时前
Rockchip debian预置安装deb包
linux·驱动开发·嵌入式硬件
天天摸鱼的java工程师6 小时前
工作中 Java 程序员如何集成 AI?Spring AI、LangChain4j、JBoltAI 实战对比
java·后端
星辰_mya6 小时前
RockerMQ之commitlog与consumequeue
java·开发语言
꧁Q༒ོγ꧂6 小时前
C++ 入门完全指南(六)--指针与动态内存
开发语言·c++
梁山1号6 小时前
【关于CAN】
c语言·stm32·单片机
叫我:松哥6 小时前
基于 Flask 框架开发的在线学习平台,集成人工智能技术,提供分类练习、随机练习、智能推荐等多种学习模式
人工智能·后端·python·学习·信息可视化·flask·推荐算法
IT=>小脑虎6 小时前
2026版 Go语言零基础衔接进阶知识点【详解版】
开发语言·后端·golang
ChangYan.6 小时前
ffi-napi运行失败,报错:No native build was found,解决办法
开发语言
专注VB编程开发20年6 小时前
压栈顺序是反向(从右往左)的,但正因为是反向压栈,所以第一个参数反而离栈顶(ESP)最近。
java·开发语言·算法
VekiSon6 小时前
综合项目实战——电子商城信息查询系统
linux·c语言·网络·http·html·tcp·sqlite3