C++11 模板类array
2023-12-25 10:34:54
????????vector类的功能比数组强大,但付出的代价时效率稍低。如果您需要的时长度固定的数组,使用数组时更佳的选择,但代价时不那么方便和安全。有鉴于此,C++11新增了模板类array,它也位于名称空间std中。与数组一样,array对象的长度也时固定的,也使用栈(静态内存分配),而不是自由存储区,因此其效率与数组相同,但更方便,更安全。要创建array对象,需要包含头文件array。array对象的创建语法与vector稍有不同:
?? ?#include <array>
?? ?...
?? ?using namespace std;
?? ?array<int, 5> nData; //创建array对象存储5个int类型
?? ?array<double, 4> dData; //创建array对象存储5个double类型
?? ?
?? ?即可以得出:
?? ?array<typeName, n_elem> arr; // 创建array对象存储n_elem个typeName类型
?? ?与vector对象不同的时,n_elem不能是变量。
?? ?在C++11中,可将列表初始化用于vector和array对象。
示例源码:
// Len_array.cpp : 此文件包含 "main" 函数。程序执行将在此处开始并结束。
//
#include <iostream>
#include <array>
using namespace std;
int main()
{
array<int, 5> nData= { 1,2,3,4,5 };
array<double, 6> dData1 = { 1.1, 1.2, 1.3, 1.4, 1.5, 1.6 };
array<double, 6> dData2 = { 2.1, 2.2, 2.3, 2.4, 2.5, 2.6 };
array<double, 6> dDataResult;
for (int i = 0; i < 5; i++)
{
printf("nData[%d] = %d\n", i, nData[i]);
}
printf("\n");
for (int i = 0; i < 6; i++)
{
dDataResult[i] = dData1[i] + dData2[i];
printf("dDataResult[%d] = %lf\n", i, dDataResult[i]);
}
}
执行结果:
文章来源:https://blog.csdn.net/wendyWJGU/article/details/135173800
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!