RELATEED CONSULTING
相关咨询
选择下列产品马上在线沟通
服务时间:8:30-17:00
你可能遇到了下面的问题
关闭右侧工具栏

新闻中心

这里有您想知道的互联网营销解决方案
C++11的array容器怎么使用

本篇内容介绍了“C++11的array容器怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!                              

成都创新互联公司凭借专业的设计团队扎实的技术支持、优质高效的服务意识和丰厚的资源优势,提供专业的网站策划、网站制作、成都做网站、网站优化、软件开发、网站改版等服务,在成都十多年的网站建设设计经验,为成都数千家中小型企业策划设计了网站。

内置数组

数组是C语言中最常用的数据结构之一,但是它的使用比较麻烦。首先是大小没有管理,二是越界操作没有检查。虽然C/C++也提供了一些解决办法,但总是不够完美。例如下面的代码:

int ary[5];
memset(ary, 0, sizeof(ary));
unsigned int i = 0;
while(i   ary[i] = i;
   i++;
}

对于元素的个数通过sizeof计算数组中元素的个数,是否越界,就只能靠程序员自己来保证了。

array容器

C++11中引入了array容器,基本上解决了内置数组的问题:

std::array c11ary;
c11ary.fill(0);
unsigned int i = 0;
while(i   c11ary.at(i) = i;
   i++;
}


这段代码中,

  1. 使用fill方法实现了数据填充。

  2. 使用size方法取得数组的大小。

  3. 虽然at(i)方法实现带有越界检查的读写。

没有免费的误餐

为了了解array容器的性能,我们编写下面的代码来测试写入效率:

DWORD begin = GetTickCount();
std::array ary;
//int ary[10000];
//std::vector ary(10000,0);
std::cout << sizeof(ary) << std::endl;
for(int s = 0; s < 10000; s++){
   for(int i = 0; i < 10000; i++){
       ary[i] = s + i;
   }
}
DWORD end = GetTickCount();
std::cout << end - begin << std::endl;

代码分别使用array容器,内置数组,vector容器进行了确认,结果如下:

首先是占用空间的比较结果:array容器和内置数组占用相同的内存空间,vector只有12Byte,真正用于保存数据的内容应该是从堆中获取的。

写入速度的比较结果:内置数组的速度最快,vector容器次之,array容器最慢。

但从array和内置数组的比较结果来讲,牺牲了一些性能,换来了安全和便利。但是vector的效率超过array,让人很意外。

“C++11的array容器怎么使用”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注创新互联网站,小编将为大家输出更多高质量的实用文章!


分享名称:C++11的array容器怎么使用
文章地址:http://scyingshan.cn/article/jpeosc.html