博客
关于我
C/C++编程笔记:C语言中的指针和数组之间的区别?
阅读量:85 次
发布时间:2019-02-25

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

指针与数组的区别及 sizeof 运算符的行为

指针和数组在许多方面看起来相似,但它们是两个不同的概念。以下将通过具体例子说明两者的区别,并解释 sizeof 运算符的行为。

指针与数组的区别

  • 动态分配与静态分配

    指针用于存储动态分配的数组地址,而数组是静态分配的。指针可以通过动态分配函数(如 mallocnew)获得任意大小的内存块。

  • 类型兼容性

    在 C 语言中,数组和指针通常是不同的类型。例如,int [2]int * 是不兼容的类型。尝试将指针赋值给数组会导致编译器错误。

  • 数组的特殊属性

    数组在语言实现中特殊地处理了存储空间,数组名称直接给出第一个元素的地址。这种属性使得数组在某些方面与指针行为类似。

  • sizeof 运算符的行为

    sizeof 运算符用于获取变量或数据类型的大小。它的行为在 C 和 C++ 中有所不同。

  • C 中的 sizeof

    在 C 语言中,sizeof 运算符返回变量或数据类型所占内存的大小,结果为 char 类型。例如:

    sizeof(arr)    // 返回数组 arr 的大小sizeof(ptr)   // 返回指针 ptr 的大小
  • C++ 中的 sizeof

    在 C++ 中,sizeof 的行为与 C 类似,但返回值通常以 size_t 类型表示。size_tunsigned char 的扩展类型,避免了负值问题。

  • 示例程序

  • C 程序

    int arr[24];int *ptr = malloc(sizeof(int) * 24);
  • C++ 程序

    int arr[24];int *ptr = new int[24];
  • 输出结果

    • C

      arr [24] 的大小 24ptr 4 的大小* ptr = 10
    • C++

      编译器错误:分配给时类型不兼容从 'int *' 类型输入 'int [2]'

      这一错误表明数组和指针的类型不兼容。

    数组作为指针传递

    数组参数始终作为指针传递,即使使用方括号。例如:

    void func(int arr[24]);

    在编译时,arr 被视为指针,arr[i] 被编译为 *(arr + i)

    总结

    通过以上内容可以看出,虽然数组和指针在某些方面有相似之处,但它们是不同的概念。理解这些差异有助于更好地使用它们在不同场景中。

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

    你可能感兴趣的文章
    oppo后端16连问
    查看>>
    Optional类:避免NullPointerException
    查看>>
    Optional讲解
    查看>>
    ORA-00932: inconsistent datatypes: expected - got NCLOB【ORA-00932: 数据类型不一致: 应为 -, 但却获得 NCLOB 】【解决办法】
    查看>>
    ORA-00942 表或视图不存在
    查看>>
    ORA-01034: ORACLE not available
    查看>>
    ORA-01152: 文件 1 没有从过旧的备份中还原
    查看>>
    ORA-01795: 列表中的最大表达式数为 1000
    查看>>
    ORA-06575: 程序包或函数 NO_VM_DROP_PROC 处于无效状态
    查看>>
    ORA-08102的错误
    查看>>
    ORA-12505, TNS:listener does not currently know of SID given in connect descriptor异常
    查看>>
    ora-12541:tns:no listener
    查看>>
    【docker知识】联合文件系统(unionFS)原理
    查看>>
    ORACEL学习--理解over()函数
    查看>>
    oracle 10g crs命令,Oracle 10g CRS安装问题解决一例
    查看>>
    oracle 10g的安装配置
    查看>>
    Oracle 11.2.0.4 x64 RAC修改public/private/vip/scan地址
    查看>>
    Oracle 11G INDEX FULL SCAN 和 INDEX FAST FULL SCAN 对比分析
    查看>>
    Oracle 11g UNDO表空间备份增强
    查看>>
    Oracle 11g 使用RMAN备份数据库
    查看>>