C++ 编程:数组的定义

文若2年前技术文章758

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() 有些像了。



相关文章

hive元数据操作

1.查看hive从超过5000分区的表select dbs.name, tbls.TBL_NAME, count(1) as part_count from dbs, tbls, partitions...

mysql 导出 csv 参数 secure_file_priv 设置

mysql 导出 csv 参数 secure_file_priv 设置

一、功能secure_file_priv 参数是用来限制数据导入和导出操作的效果,例如由LOAD data和SELECT…INTO OUTFILE语句和LOAD_FILE()函数。只有具有“FILE”...

MapReduce生产经验

MapReduce程序效率的瓶颈在于两点:1)计算机性能(1)CPU、内存、磁盘、网络2)I/O操作优化(1)数据倾斜(2)Map运行时间太长,导致Reduce等待过久(3)小文件过多下来就根据这两点...

MySQL运维实战之ProxySQL(9.3)使用ProxySQL实现读写分离

proxysql读写分离主要通过mysql_query_rules表中的规则来实现。下面是具体的配置步骤:hostgroup配置insert into mysql_servers&...

greenplum安装配置

一、配置服务器安装环境1、修改服务器内核参数(所有节点)编辑sysctl.conf,需要设置共享内存Greenplum数据库使用共享内存在属于同一postgres实例的postgres进程之间进行通信...

oracle开启关闭归档

一、开启归档1.开启前准备:备份spfileCreate pfile='d:pfileSID.ora' from spfile;OS上创建归档目录:+DATA_DG/arch设置归档路径:alter...

发表评论    

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