我的编程空间,编程开发者的网络收藏夹
学习永远不晚

C++数组的定义详情

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

C++数组的定义详情

上一篇讲解了类型,通过类型来开始本篇的学习;


int a[10];

上述代码中的a是什么类型呢?

相信很多人都知道是一个数组类型,具体来说是一个int[10]的类型;

1.数组概念

定义:将一到多个相同对象串连到一起,所组成的类型;

初始化方式:

  • 缺省初始化int x[5];
  • 聚合初始化int x[] = {1,2,3};

注意:

  • 不能用auto来声明数组类型;
  • 数组不能复制,也不能赋值;

2.数组的复杂声明

指针数组的声明:


int *i[5];

大家思考下i的类型是什么?

指针数组表示数组内的每个元素都是int*类型,所以i的类型为int *[5];

数组指针的声明:


int (*x)[5];

大家思考下x的类型是什么?

这里a是一个指针,类型为int(*)[5];

3.数组到指针

  • 使用数组对象时,通常会产生数组到指针的隐式转换;
  • 可通过引用声明来避免隐式转换;

int a[3] = {1, 2, 3};
auto b = a;  // b的类型为int*
auto &b = a; // b的类型为int(&) [3]

数组和指针的转换关系图

指向数值开头的指针很好获得,比如a、&(a[0])、std::begin(a);

获取指向数组结尾的指针(上图指向80):a+3、&(a[3])、std::end(a);

使用标准库获取开头和结尾指针的方法在别的数据类型也适用;

4.数组操作

4.1获取数组元素个数


int x[3];
// 方法一
std::cout << sizeof(x) / sizeof(int) << std::endl;
// 方法二
std::cout << std::size(a) << std::endl;
// 方法三
std::cout << std::end(a) - std::begin(a) << std::endl; 

方法三实际上是在运行期才执行的,增加程序运行耗时,不推荐;

方法一类型需要自己传入,适用性差,不推荐;

推荐用方法二;

4.2使用for循环遍历数组(C++11开始支持)


int a[3] = {1, 2, 3};
for (int x: a)
{
 std::cout << x << std::endl;
}

5.拓展

5.1C字符串

  • C字符串本质也是数组;
  • 声明一个字符数组并打印长度

#include <cstring>
char a[] = "Hello";
std::cout << strlen(a) <<std::endl;

使用函数strlen需要引入头文件cstring

5.2vector

定义:是C++标准库中定义的类模板;

与内建数组相比,更侧重于易用性(相对而言性能比内建数组差),可复制,可在运行期动态改变元素个数;
初始化与构建


// 1、聚合初始化
std::vector<int> x = {1, 2, 3};
// 2、其他初始化方式
std::vector<int> x(3, 1); // 个数为3,并且每个元素都为1

vector的初始化方式还有很多,可参考:https://en.cppreference.com/w/cpp/container/vector/vector

获取元素个数


std::cout << x.size() << std::endl;

判断为空


std::cout << x.empty() << std::endl;

尾部添加元素


x.push_back(2);  // 向容器中添加一个整数2

删除最后一个元素


x.pop_back();

打印vector中的元素


std::vector<int> x = {1, 2, 3};
x[2];   // 跟数组一样,越界不报错
x.at(2);  // 不可以越界

在标准库中的beginend函数,在vector中也有同名的方法并且作用相同,返回一个迭代器;

可以使用指针引用一个vector对象的方法:


std::vector<int> x = {1, 2, 3};
std::vector<int>* p = &x;
std::cout << p->size() << std::endl;

5.3string

定义:是C++标准库中定义的一个类模板特化别名,用于内建字符串的替代品;

  • 与内建字符串相比,更侧重易用性,可复制,可在运行期动态改变字符串个数;
  • 构造和初始化,可参考:https://en.cppreference.com/w/cpp/string/basic_string
  • 支持比较、赋值、拼接、索引、转换为C字符串(c_str());

6.思考

6.1思考以下代码输出什么?


int i[3] = {1, 2, 3};
std::cout << *(a) << std::endl;   // 第一行
std::cout << *(a + 1) << std::endl;  // 第二行

第一行的输出是1,第二行输出的是2,这就相当于a[0]和a[1]的值,说明数组底层也是指针实现,第二行中加一表示首地址地址移动类型大小的字节;

6.2以下代码能够编译通过吗?


int a[2] = {1, 2};
std::cout << a[100] << std::endl;

这个数组越界在C++中是可以编译通过的,会输出一个毫无关系的值,编译器不会有边界检查,需要特别注意!

6.3在另一个文件中定义了数组,如何在该文件中定义?


test.cpp:

int arr[3] = {1, 2, 3};

main.cpp:

extern int arr[];

上述声明称为不完整类型的声明,可以在main.cpp中找到test.cpp定义的数组;

总结:

本篇简要介绍了数组的常用方法以及C++标准库提供的一些关于数组的容器,大家也可以从思考部分来了解数组的一些细节;

到此这篇关于C++数组的定义详情的文章就介绍到这了,更多相关C++数组内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

C++数组的定义详情

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

c++中二维数组的定义

在 c++ 中,二维数组的定义格式为:数据类型 数组名行数。元素通过 行索引 访问。可通过嵌套大括号或动态分配初始化。动态分配后需释放内存以避免泄漏。C++ 中二维数组定义定义格式:数据类型 数组名[行数][列数];
c++中二维数组的定义
2024-05-08

c++中数组怎么定义

c++ 中数组是存储相同数据类型连续元素的内存块。定义数组语法为:数据类型 数组名[数组大小]。数组元素从 0 开始索引访问。数组特性包括:连续内存存储、固定大小、可作为参数或返回值。注意事项是避免索引超出范围和声明时必须指定数组大小。C+
c++中数组怎么定义
2024-04-26

c++可变数组如何定义

在C++中,可变数组可以使用动态内存分配的方式进行定义和操作。以下是几种常见的定义可变数组的方式:使用指针和new操作符:int size = 10; // 可变数组的大小int* arr = new int[size]; // 使用n
c++可变数组如何定义
2023-10-28

C#中怎么定义一个数组

这篇文章给大家介绍C#中怎么定义一个数组,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。C#定义数组一、一维:int[] numbers = new int[]{1,2,3,4,5,6}; //不定长 int[]
2023-06-17

c#数组怎么定义和赋值

在C#中,可以使用以下方式定义和赋值数组:1. 使用数组初始化器:```csharpint[] numbers = { 1, 2, 3, 4, 5 };```2. 使用new关键字和数组大小进行定义:```csharpint[] numbe
2023-08-18

c语言怎么定义vector数组

在C语言中,我们可以使用动态内存分配来定义一个类似于vector的数组。首先,我们需要定义一个结构体来表示这个数组,其中包含一个指向实际数据的指针和当前数组的长度和容量。typedef struct {int* data;int siz
c语言怎么定义vector数组
2024-02-29

c++中如何定义二维数组

在 c++ 中定义二维数组的方法:声明数组类型:int arr行数;使用嵌套循环初始化数组元素;使用下标运算符访问数组元素。C++ 中定义二维数组在 C++ 中,二维数组是一种数据结构,用于存储按行和列组织的数据。要定义二维数组,可以使用
c++中如何定义二维数组
2024-05-09

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录