C++ 编程:数组的定义

文若2年前技术文章662

1. 什么是数组?

数组让能够按顺序将一系列相同类型的数据存储到内存中 C++ 中的数组可分为静态数组动态数组 两种。

2. 静态数组

首先介绍声明一个 静态数组 的语法:

/* ElementType ArrayName [constant_number of elements] = {optional initial values}; */
int myArray[10] = {0};

首先需要先声明数组中存储的数据类型,然后就是数组名及元素个数,这样的数组被称为静态数组,因为在编译阶段,它们包含的元素数以及占用的内存量都是固定的。

3. 数组如何存储数据?
int myArray[5] = {10, 20, 30, 40, 50};

👆数组占用的内存空间包含 5 块,每块的大小都相同。块大小取决于数组存储的数据类型,这里是 int 编译器为数组 myArray 预留的 内存量为 sizeof(int) * 5。

#include <iostream>

using namespace std;

int main() {
   int myArray[5] = {10, 20, 30, 40, 50};

   std::cout << "一个 int 的长度为:" << sizeof(int) << std::endl;
   std::cout << "一个 4 个 int 元素,数组的长度为:" << sizeof(myArray) << std::endl;
   std::cout << myArray[0] << std::endl;

   return 0;
}

// 输出:
// 一个 int 的长度为:4
// 一个 4 个 int 元素,数组的长度为:20

再者就是一个索引的概念,Python 中叫下标,都是从 0 开始标记第一个元素。

4. 访问数组中的元素

下面通过例子来理解索引(下标)的作用。需要注意的是我们创建的静态数组是有边界的,如果使用索引越过边界会导致程序奔溃。

#include <iostream>


using namespace std;

int main() {
   int myArray[5] = {10, 20, 30, 40, 50};

   std::cout << "First element at index 0: " << myArray[0] << std::endl;
   std::cout << "Second element at index 1: " << myArray[1] << std::endl;
   std::cout << "Third element at index 2: " << myArray[2] << std::endl;
   std::cout << "Fourth element at index 3: " << myArray[3] << std::endl;
   std::cout << "Fifth element at index 4: " << myArray[4] << std::endl;

   return 0;
}
4. 修改数组中的元素
#include <iostream>


using namespace std;

int main() {
   int myArray[5] = {10, 20, 30, 40, 50};

   myArray[0] = 8023;

   std::cout << myArray[0];
   return 0;
}
5. 动态数组

上面介绍的是 静态数组,即在编译阶段就需要指定长度,某些场景下我们不知道数组应该预留多数长度,例如我们在程序中存储处理医院的病历,我们无法知道将要处理多少病历,即使我们对上限进行合理估计,我们将预留大量内存,这样会影响到系统性能。C++ 中为我们提供动态数组,即在运行阶段根据需要动态增大的数组。

#include <iostream>
#include <vector>

using namespace std;

int main()
{
   // 创建一个动态数组
   vector<int> dynArray (3);

   dynArray[0] = 365;
   dynArray[1] = -421;
   dynArray[2]= 789;

   // 打印数组的元素个数
   cout << "Number of integers in array: " << dynArray.size() << endl;

   // 用户输入一个元素
   cout << "Enter another element to insert" << endl;
   int newValue = 0;
   cin >> newValue;
   // 将元素插入数组
   dynArray.push_back(newValue);

   // 打印数组元素个数
   cout << "Number of integers in array: " << dynArray.size() << endl;
   
   // 输出最后一个元素,既我们手动加入的元素
   cout << "Last element in array: ";
   cout << dynArray[dynArray.size() - 1] << endl;

   return 0;
}

通过上面的代码我们可以了解到如何创建动态数组,及如何获得数组元素数量,及如何向动态数组中添加一个元素。从功能上看,就与 Python 中的 list() 有些像了。



相关文章

用了函数就无法使用索引?MySQL函数索引值得你拥有

MySQL中的索引,就像图书馆里的索引卡片,帮我们快速定位到想要的信息。但是,如果你对这些卡片动了点“手脚”,比如用个函数来“改造”一下索引字段,那么这些卡片可能就不再那么有效了,查找起来就得费劲多了...

k8s删除Terminating状态的命名空间

问题描述Kubernetes中namespace有两种常见的状态,即Active和Terminating状态,其中Terminating状态一般会比较少见,当对应的命名空间下还存在运行的资源,但该命名...

静默安装oracle11g单实例

环境: CentOS 7.8 11.2.0.4.0 orclp:172.16.104.31一、准备1、依赖包检查pdksh 在 redhat 上叫 ksh检查是否有安装root# rpm -q bin...

kubernetes HPA

kubernetes HPA

Horizontal Pod Autoscaling 可以根据 CPU 利用率自动伸缩一个 ReplicaSet、Deployment 或者中的 Pod 数量cat hpa-deploy.yaml a...

Kubernetes源码解读(一)--WorkQueue源码分析

Kubernetes源码解读(一)--WorkQueue源码分析

 WorkQueue被称为工作队列,kubernets的WorkQueue队列与普通FIFO队列相比多了以下特性:有序:按照添加顺序处理元素(item)去重:相同元素在同一时间不会被重复处理,例如:一...

win内存使用率过高但是资源监视器查看不到进程,排查思路

win内存使用率过高但是资源监视器查看不到进程,排查思路

问题现象:服务器:某云服务器 内存使用率持续打高,但是通过任务管理器查不到占用内存很高的进程排查步骤:1、通过任务管理器分析核查目标主机的内存使用趋势情况,近7天内存使用情况如下:通过任务管理器排查内...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。