博客
关于我
指针与数组、函数
阅读量:386 次
发布时间:2019-03-05

本文共 1311 字,大约阅读时间需要 4 分钟。

《C Primer Plus》阅读笔记

一、指针与数组的表示方法

  • 指针与数组的优缺点
    使用数组表示法能让函数处理数组的意图更加明显。许多其他语言的程序员对数组表示法更熟悉,比如FORTRAN、Pascal、Modula-2或BASIC。而指针表示法则更自然,尤其是与递增运算符结合时更接近机器语言,编译器能生成更高效的代码。但程序员认为代码优化应由编译器负责,主要任务是确保代码正确与逻辑清晰。
  • C语言中,ar[i]* (ar+1)是等价的,无论ar是数组名还是指针变量都没问题。但只有当ar是指针变量时,才能使用ar++这样的表达式。指针表示法在处理数组时更灵活,尤其是在动态分配存储空间时更具优势。

    1. 一维数组的指针表示
      int * p;
      声明一个指向int类型的指针,功能上与一维数组类似。通过* (p+i)可以对存储单元进行赋值,与数组表示法效果相同。指针表示法的优势在于可以动态分配存储空间,而数组则需要预先分配。
    2. 以下是指针表示法的一维数组示例:

      #include 
      int main(void) { int *p, i, n; scanf("%d\n", &n); for (i=0; i < n; i++) { // 读取输入并赋值 * (p + i) = ...; }}
      1. 数组形参的声明

        int sum(int *ar, int n):函数接收数组首地址和长度。
        int sum(int ar[], int n):函数接收数组名和长度。
        int sum(int *str, int *end):可以分别传递数组的起始地址和结束地址,适用于处理更大范围的数组。

      2. 指针的基本用法

        指针的主要用途是函数间信息传递,尤其是需要修改主调函数变量时。常见场景是处理数组时,通过指针实现动态分配或多维数组操作。

      3. 二、指针与多维数组

      4. 二维数组的表示
        int a[3][4];
        这是一个主数组,包含3个元素,每个元素是内含4个int值的数组。
        a是主数组的首元素地址,与&a[0]相同。a[0]则是内含4个int值的数组的首元素地址,与&a[0][0]相同。
      5. 通过指针解引用可以获取原始值:

        * (* (a + 1) + 1) 表示二维数组第2个元素的第2个值。

        1. 二维数组的指针表示
          使用二级指针表示二维数组:
        2. int **a; a = (int**)malloc(sizeof(int*) * m);// 创建了一个m*n的二维数组,与`a[m][n]`等效。
          1. 指针与二维数组的关系

            int a[3][4]; int (*b)[4];
            b = a;
            b声明为指向4个int值数组的指针,因为a是二维数组的首元素地址,而每个元素是一个内含4个int值的数组。

          2. 二维数组与函数

            函数参数中二维数组的表示:

          3. void sum(int a[][len], int row); // len不能省略void sum(int (*b)[len], int row); // len不能省略

            这些函数接收数组的首地址和行数,适用于处理具有固定列数的二维数组。

    转载地址:http://liqwz.baihongyu.com/

    你可能感兴趣的文章
    Plotly:如何手动设置 plotly express 散点图中点的颜色?
    查看>>
    Plotly:如何结合 make_subplots() 和 ff.create_distplot()?
    查看>>
    Plotly:如何绘制累积的“步骤“;直方图?
    查看>>
    Quartz进一步学习与使用
    查看>>
    Plotly条形图-根据正/负值更改颜色-python
    查看>>
    PLSQL developer12安装图解
    查看>>
    PLSQL Developer调试 存储过程和触发器
    查看>>
    PLSQL window操作
    查看>>
    plsql 存储过程 测试
    查看>>
    plsql 安装后database下拉没有东西
    查看>>
    PLSQL_Oracle PLSQL内置函数大全(概念)
    查看>>
    PLSQL_案例优化系列_体验逻辑结构如何影响SQL优化(案例3)
    查看>>
    PLSQL中INDEX BY TABLE的 DELETE操作
    查看>>
    plsql学习笔记---plsql相关概念,以及基础结构
    查看>>
    plsql数据库异常---plsql 登录后,提示数据库字符集(AL32UTF8)和客户端字符集(ZHS16GBK)不一致
    查看>>
    plsql查询乱码问题解决
    查看>>
    PLSQL的DBMS_GETLINE
    查看>>
    quartz简单demo,教你最快使用quartz
    查看>>
    PlutoSDR学习笔记(一)—函数API手册
    查看>>
    Quartz安装包中的15个example
    查看>>