• 15.0、C语言——指针详解(1)


    15.0、C语言——指针详解(1)

    1. int main() {
    2. char* p = "abcdef"; //这是一个常量字符串
    3. printf("%c",*p); //这里打印出来的结果是 a
    4. printf("%s",p); //这里打印出来的是 abcdef
    5. return 0;
    6. }

            这里的 char* p = "abcdef"; 并不是说要将该字符串赋值给指针变量 p ,而是将该字符串的首地址存到 p 中(也就是将 a 的地址存进去),那么
            第一个 printf 打印的是 %c 字符串,p存的是&a,那么*p就是a,所以结果的就是 a,
            第二个 printf 打印的是 %s, 从a这个地址开始打印字符串直到 '\0' 处停止,结果出来的就是 abcdef
            【这里注意:以这种形式创建字符串的话,那么"abcdef"就是常量字符串,不可更改,相当于const char* p = "abcdef"; 这样写代码也更加的标准和健壮】

    下面来看一道面试题:请问打印出来的结果是什么?

    1. #define _CRT_SECURE_NO_WARNINGS 1
    2. #include
    3. int main() {
    4. char* p1 = "abcdef";
    5. char* p2 = "abcdef";
    6. if(p1 == p2) {
    7. printf("p1==p2");
    8. }
    9. else {
    10. printf("pq != p2");
    11. }
    12. return 0;
    13. }

            最后打印出来的结果是 p1 == p2,因为前面也说到了这是一个常量字符串,不可修改只能使用,那既然不能修改那就没有必要创建两个一模一样的了呀,为了节省内存空间,所以p1、p2都指向同一块地址&a 

    指针数组

    指针数组:存放指针类型数据的数组

    声明方式、引用和普通数组方式相似,,代码如下:

    1. #define _CRT_SECURE_NO_WARNINGS 1
    2. #include
    3. int main() {
    4. int arr1[] = {1,2,3,4,5};
    5. int arr2[] = {7,8,9,10,11};
    6. int arr3[] = {12,13,14,15,16};
    7. int* parr[] = {arr1,arr2,arr3};
    8. return 0;
    9. }

    数组指针:

    数组指针的定义

            我们已经熟悉:整型指针  int* p;能够指向整型数据的指针,浮点型指针 float* pf 能够指向浮点型数据的指针
            那数组指针应该是:能够指向数组的指针

            之前也说到过 int arr[3] = {1,2,3}; &arr 表示的是整个数组的地址:
            那么数组指针就是用来存放这类型的元素的,int (*p)[10] = &arr;   由于 ' [ ] ' 的优先级比 ' * ' 要高,所以如果直接写 int*p[10] 那么 p 就变成一个数组就不是指针了,所以应该 int (*p)[10] = &arr;  先和 ' * ' 结合才可以~

    数组指针 应该如何存储 指针数组 ?代码如下:

    1. int main() {
    2. int* arr[5] = { 0 };
    3. int* (*pa)[5] = &arr;
    4. return 0;
    5. }

            int* 表示数组的类型;
           *pa 表示该变量是一个指针变量【在变量定义的过程中 *p 不代表解引用操作】;
            [ 5 ]代表指向的数组可存放 5 个元素

    接下来看看 数组指针 在 二维数组 中的用法:

            我们知道一维数组名代表的是首元素地址,那么在二维数组中 数组名 代表的也是首元素地址,只不过该首元素是二维数组中第一行的整个一维数组,我们需要把二维数组中的每一行看成一个元素,
            那么二维数组名就是第一行整个一维数组的地址,那么接下来看看如何利用 数组指针 去遍历一个二维数组的所有元素 ->

    1. int main() {
    2. int arr[3][6] = {{1,2,3,4,5,6},{2,3,4,5,6,7},{3,4,5,6,7,8}};
    3. int(*pa)[6] = arr;
    4. int i = 0;
    5. int j = 0;
    6. for (i = 0; i < 3;i++) {
    7. for (j = 0; j < 6;j++) {
    8. printf("arr[%d][%d] = %d \n", i, j, (*(pa + i))[j]);
    9. }
    10. printf("\n");
    11. }
    12. return 0;
    13. }

            pa 代表的是二维数组 arr 中首元素的地址【也就是第一行整个一维数组的地址】;
           *pa 代表的是第一行一维数组的数组名,也就是第一行一维数组的首元素地址【因为数组名代表首元素地址】
            pa + i 就会跳过 i 个一维数组,*(pa + i)就相当于整个一维数组的数组名 ;
          【我们知道 指针+1 就会跳过一个该指针类型的距离;
            比如 整型指针 + 1 就会跳过一个整型的距离;字符 类型指针 + 1 就会跳过一个字符类型的距离;
            那么 数组指针 + 1 就会跳过一整个数组的距离】

            那么 (*( pa + i ) )[ j ]  代表的就是 第 i 行一维数组中的第 j 个元素;

    总结一下:

     

  • 相关阅读:
    Java之IO属性集(Properties)
    Rust星号(*)的作用-基础篇
    数字档案室建设评价
    短视频脚本如何创作?了解构成部分很关键,按顺序做不会错
    【2023】redis-stream配合spring的data-redis详细使用(包括广播和组接收)
    从零开发一款相机APP 第九篇: Camera2相机 录像功能实现
    如何优雅的加密配置文件中的敏感信息
    win11解决80端口默认被占用的问题
    从0开始在Vscode中搭建Vue2/3项目详细步骤
    机器学习常见知识点 2:决策树
  • 原文地址:https://blog.csdn.net/m0_52433668/article/details/126541165