通过与 Jira 对比,让您更全面了解 PingCode

  • 首页
  • 需求与产品管理
  • 项目管理
  • 测试与缺陷管理
  • 知识管理
  • 效能度量
        • 更多产品

          客户为中心的产品管理工具

          专业的软件研发项目管理工具

          简单易用的团队知识库管理

          可量化的研发效能度量工具

          测试用例维护与计划执行

          以团队为中心的协作沟通

          研发工作流自动化工具

          账号认证与安全管理工具

          Why PingCode
          为什么选择 PingCode ?

          6000+企业信赖之选,为研发团队降本增效

        • 行业解决方案
          先进制造(即将上线)
        • 解决方案1
        • 解决方案2
  • Jira替代方案

25人以下免费

目录

为什么不存在引用的数组

因为数组是存放对象的地方,引用不是一个对象。指针和引用最大的区别就是指针是一个对象,引用不是对象。引用和指针不同。引用只是别名,没有确定的大小,必须引用一个确定存在的变量。

一、为什么不存在引用的数组

因为数组是存放对象的地方,引用不是一个对象。指针和引用最大的区别就是指针是一个对象,引用不是对象。引用和指针不同。引用只是别名,没有确定的大小,必须引用一个确定存在的变量。

如果给了一个引用的数组,该如何分配空间呢?指针可以给一个NULL值或者nullptr,但是引用不行。

没有引用数组的原因

(1)引用数组指的是引用类型的数组,也就是数组的各个成员是引用&类型,这是在c++中不能实现的

(2)c++中,引用可以说只是某个变量的别名,所谓别名,是和指针类型区分开的:指针类型也可以

指向某个变量,但指针类型本身也是一个变量,而引用实际上不是一个变量。更本质来说,可以

理解为引用没有自身的地址,不占用内存空间(这里为了简化问题可以这样考虑)。因此,

声明引用数组没有办法分配空间,因为根本就没有空间可以分配给引用。所以不能声明和定义引用数组

(3)C++不支持传统意义的复制:

传统的复制为:int a = b;

这里a和b在内存中分别占用不同的内存空间,但是内容一致。

如果int& a = b; 这个时候,内存中a并不被分配内存,所以没有复制可言。

所以对于数组元素是引用来说,没法完成元素的复制操作,没有给数组分配内存,所以数组中的元素不能是引用。

延伸阅读:

二、数组的引用的作用(存在)

(1)作为形参(防止数组退化为指针)

int func(int array[]);

int func(int array[10]);

int func(int* array);

在func中是无法知道数组的大小,如果开发者必须提前知道数组的大小,就需要用到数组的引用做参数

例如,int(&a)[2],可以有效的防止数组退化。也就是,数组作为函数参数传递过去后,仍然是一个数组。

优点:节省内存消耗,不用拷贝一份数组,直接使用原数组(甚至可以修改原数组)

#include <iostream>

using namespace std;

int func(int(&a)[6])

{

    int count = 0;

    for (int i = 0; i < 6; i++)

    {

       count += a[i];

    }

    return count;

}

int main()

{

    int a1[6] = { 1,2,3,4,5,6 };

    int count = func(a1);

    cout << “count:” << count << endl;

    return 0;

}

代码安全性提高:

如果将 int a1[6] = { 1,2,3,4,5,6 }; 改为 int a1[5] = { 1,2,3,4,5 };

编译会报错说明编译时将进行数组长度的检查

(2)作为返回类型

函数不能直接返回数组,但是可以返回数组的指针和数组的引用,还需要注意,返回的不能是栈对象,

因为栈对象很快会被销毁

有关定义:

题目:编写一个函数的声明,使其返回包含10个string对象的数组的引用

//不用类型别名

string(&func(形参))[10];

//类型别名

using arr = string[10];

arr& func(形参);

typedef string(&arr)[10];

arr func(形参);

//尾置返回类型

auto func(形参)->string(&)[10];

//decltype关键字

string ss[10];

decltype(ss) &func(形参)

相关文章