数组指针,整形指针,字符指针

简介: 数组指针,整形指针,字符指针
#include<stdio.h>
//数组指针是一种指针--指向数组
// 
//整形指针--指向整型的指针
//字符指针--指向字符的指针
//int main()
//{
//    int a = 10;
//    int* pa = &a;//整形指针
//    char ch = 'w';
//    char* pb = &ch;//字符指针
//    int arr[10] = { 1,2,3,4,5 };
//    arr;//是错误的,因为数组名是首元素地址---arr[0]
//    int(* pc)[10] = &arr;//取出的是数组的地址   arr指向的是数组 此时的pc是数组指针
//    double *d[5];//d是数组名,数组5个元素,double说明每个元素是double型
//    double*(*pd)[5] = &d;//(*pd)说明pd是指针,指向数组,数组5个元素,double说明每个元素是double型
//    return 0;
//}
// 
// 
//int main()
//{
//    int arr[10] = { 0 };//结果相同,但是意义不同
//    printf("%p\n", arr);//000000C9F97CF6D8数组名表示首元素地址
//    printf("%p\n", &arr);//000000C9F97CF6D8取出的是数组的地址        若想存储在p中,存储方式不同
//    int* p1 = arr;
//    int(*p2)[10] = &arr;//p1  p2结果相同,但是意义不同
//    printf("%p\n", p1); //000000C9F97CF6D8
//    printf("%p\n", p2);//000000C9F97CF6D8
//    printf("%p\n", p1+1);//000000C9F97CF6DC
//    //+1跳过的是一个元素的地址(4)(p2指向的是首元素的地址)
//    printf("%p\n", p2+1);//000000C9F97CF700
//    //+1跳过的是整个数组(40)(p2指向的是数组地址)
//    return 0;
//}
//数组名是首元素地址
//但是有两个例外:
//1:sizeof(数组名)---数组名表示整个数组,计算的是整个数组大小,单位是字节
//2:&数组名---数组名表示整个数组,取出的是整个数组的地址
//打括号()就是数组地址,不打括号就是指针数组
// 
//两种不同思路和方法:
//int main()//解引用法
//{
//    int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };
//    int* p1 = arr;//取出的是首元素地址,此时(方法一)使用for循环打印数组比较方便,如下
//    int i = 1;
//    for (i = 0; i < 10; i++)
//    {
//        printf("%d ", *p1 + i);//*p1是解引用,取出里面的值  &arr是打印地址
//    }
//    return 0;
//}
//int main()//指针数组法
//{
//    int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };
//    int (*p2)[10] = &arr;//取出的是整个数组地址,此时(方法二)使用for循环打印数组比较复杂,如下
//    int i = 1;//p2是指针,指向的是数组,数组是10个元素,每个元素是int型
//    for (i = 0; i < 10; i++)//(*pa)是解引用找到整个数组,即数组名,即首元素地址
//    {                       //(*pa)+i表示首元素地址逐个向后+1
//        printf("%d ", *((*p2)+i));//*((*pa)+i)表示首元素地址逐个向后+1并解引用,*表示解引用
//    }
//    return 0;
//}
//第一个思路
//void print1(int arr[3][5], int r, int c)//用数组arr接收,[3][5]表示数组行列数,用r,c表示,无返回类型
//{
//    int i = 0;
//    int j = 0;
//    for (i = 0; i < r; i++)
//    {
//        for (j = 0; j < c; j++)
//        {
//            printf("%d ",arr[i][j]);
//
//        }
//        printf("\n");
//    }
//}
第二种思路方法,,,参数部分p是数组指针,指向数组某一行
//void print2(int(*p)[5], int m, int n)//(*p)是解引用arr,表示一行地址,,[5]是首元素地址,数量5
//{
//    int i = 0;
//    int j = 0;
//    for (i = 0; i < m; i++)
//    {
//        for (j = 0; j < n; j++)
//        {
//            printf("%d ", *(*(p + i) + j));//*(p+i)表示某一行第一个元素地址,*(p+i)+j表示该行下标为j的地址
//                                                    //*(*(p+i)+j),解引用,就是第i行,下标为j的元素
//        }
//        printf("\n");
//    }
//}
//int main()
//{
//    int arr[3][5] = { {1,2,3,4,5},{2,3,4,5,6},{3,4,5,6,7} };//分别可理解为arr[0],arr[1],arr[2]
//    //写两个不同思路的函数来表示
//    print1(arr,3,5);//自己构建的打印函数
//    printf("\n");//将两种思路单纯的分隔开,无实际意义
//    print2(arr, 3, 5);//arr数组名是首元素地址,二维数组首元素是第一行所有元素!!!
//    return 0;
//}
//int(*parr2)[10];//数组指针,该指针能够指向一个数组,数组10个元素,每个元素类型是int
//int(*parr3[10])[5];  parr3是一个存储数组指针的数组,该数组能够存放10个数组指针,这每个数组指针
//能够指向一个数组,数组5个元素,每个元素是int类型


相关文章
|
11月前
使用指针访问数组元素
【10月更文挑战第30天】使用指针访问数组元素。
143 3
|
11月前
|
存储 程序员 编译器
C 语言数组与指针的深度剖析与应用
在C语言中,数组与指针是核心概念,二者既独立又紧密相连。数组是在连续内存中存储相同类型数据的结构,而指针则存储内存地址,二者结合可在数据处理、函数传参等方面发挥巨大作用。掌握它们的特性和关系,对于优化程序性能、灵活处理数据结构至关重要。
|
11月前
|
存储 NoSQL 编译器
C 语言中指针数组与数组指针的辨析与应用
在C语言中,指针数组和数组指针是两个容易混淆但用途不同的概念。指针数组是一个数组,其元素是指针类型;而数组指针是指向数组的指针。两者在声明、使用及内存布局上各有特点,正确理解它们有助于更高效地编程。
|
11月前
|
存储 C语言 计算机视觉
在C语言中指针数组和数组指针在动态内存分配中的应用
在C语言中,指针数组和数组指针均可用于动态内存分配。指针数组是数组的每个元素都是指针,可用于指向多个动态分配的内存块;数组指针则指向一个数组,可动态分配和管理大型数据结构。两者结合使用,灵活高效地管理内存。
|
11月前
|
容器
在使用指针数组进行动态内存分配时,如何避免内存泄漏
在使用指针数组进行动态内存分配时,避免内存泄漏的关键在于确保每个分配的内存块都能被正确释放。具体做法包括:1. 分配后立即检查是否成功;2. 使用完成后及时释放内存;3. 避免重复释放同一内存地址;4. 尽量使用智能指针或容器类管理内存。
|
11月前
|
存储 人工智能 算法
数据结构实验之C 语言的函数数组指针结构体知识
本实验旨在复习C语言中的函数、数组、指针、结构体与共用体等核心概念,并通过具体编程任务加深理解。任务包括输出100以内所有素数、逆序排列一维数组、查找二维数组中的鞍点、利用指针输出二维数组元素,以及使用结构体和共用体处理教师与学生信息。每个任务不仅强化了基本语法的应用,还涉及到了算法逻辑的设计与优化。实验结果显示,学生能够有效掌握并运用这些知识完成指定任务。
211 4
|
11月前
使用指针访问数组元素
【10月更文挑战第31天】使用指针访问数组元素。
130 2
|
11月前
|
算法 索引
单链表题+数组题(快慢指针和左右指针)
单链表题+数组题(快慢指针和左右指针)
113 1
|
存储
如何使用指针数组来实现动态二维数组
指针数组可以用来实现动态二维数组。首先,定义一个指向指针的指针变量,并使用 `malloc` 为它分配内存,然后为每个子数组分配内存。通过这种方式,可以灵活地创建和管理不同大小的二维数组。
|
存储
如何通过指针数组来实现二维数组?
介绍了二维数组和指针数组的概念及其区别,详细讲解了如何使用指针数组模拟二维数组,包括定义与分配内存、访问和赋值元素、以及正确释放内存的步骤,适用于需要动态处理二维数据的场景。