07--STL序列容器(Array)
一:Array了解

array<T,N> 模板定义了一种相当于标准数组的容器类型。
它是一个有 N 个 T 类型元素的固定序列。除了需要指定元素的类型和个数之外,它和常规数组没有太大的差别。
模板实例的元素被内部存储在标准数组中。
和标准数组相比,array 容器的额外幵销很小,---->比标准数组还是大一些
但提供了两个优点:
1.std::array除了有传统数组支持随机访问、效率高、存储大小固定等特点外,还支持迭代器访问、获取容量、获得原始指针等高级功能。
而且它还不会退化成指针T *给开发人员造成困惑。
2.如果使用 at(),当用一个非法的索引访问数组元素时,能够被检测到,因为容器知道它有多少个元素,
这也就意味着数组容器可以作为参数传给函数,而不再需要单独去指定数组元素的个数。
注意:
其中的元素是一个有序的集合 允许随机访问 其迭代器属于随机迭代器 其size()的结果总等于N 不支持分配器 //像vector,deque动态分配空间是需要分配器来实现的 是唯一一个无任何东西被指定为初值时,会被预初始化的容器,这意味着对于基础类型初值可能不明确 class array<> 是一个聚合体(不带用户提供的构造函数,没有private和protected的nonstatic数据成员,没有base类,有没有virtual 函数),
这意味着保存所有元素的那个成员是public,然而C++并没有指定其名称,因此对该public成员的任何直接访问都会导致不可预期的行为,也绝对不可移植。
二:array构造
array<Elem,N> c //默认构造函数; 创建一个默认初始化的数组 array<Elem,N> c(c2) //复制构造函数; 创建另一个与c2同型的vector副本(所有元素都被复制) array<Elem,N> c = c2 //复制构造函数; 创建另一个与c2同型的vector副本(所有元素都被复制) array<Elem,N> c(rv) //移动构造函数; 拿走右值rv的元素创建一个新的数组 array<Elem,N> c = rv //移动构造函数; 拿走右值rv的元素创建一个新的数组 array<Elem,N> c = initlist //使用初始化列表创建一个初始化的数组
三:array元素存取
c[idx] //返回索引idx所标示的元素,不进行范围检查 c.at(idx) //返回索引idx所标示的元素,如果越界,抛出range-error c.front() //返回第一个元素,不检查第一个元素是否存在 c.back() //返回最后一个元素,不检查最后一个元素是否存在
四:array赋值操作
c = c2 //将c2所有元素赋值给c c = rv //将右值对象rv的所有元素移动赋值给c c.fill(val) //将val赋值给数组c里的每个元素 c1.swap(c2) //交换c1和c2的数 swap(c1,c2) //交换c1和c2的数
如果使用=操作符或者swap(),两个array必须具备相同类型,即元素类型和大小必须相同。
五:迭代相关函数
c.begin() //返回一个随机存取迭代器,指向第一个元素 c.end() //返回一个随机存取迭代器,指向最后一个元素 c.cbegin() //返回一个随机存取常迭代器,指向第一个元素 c.cend() //返回一个随机存取常迭代器,指向最后一个元素 c.rbegin() //返回一个逆向迭代器,指向逆向迭代的第一个元素 c.rend() //返回一个逆向迭代器,指向逆向迭代的最后一个元素 c.crbegin() //返回一个逆向常迭代器,指向逆向迭代的第一个元素 c.crend() //返回一个逆向常迭代器,指向逆向迭代的最后一个元素
array<int, > arr = {,,,,,}; //默认补全0
for (array<int, >::iterator iter = arr.begin(); iter != arr.end(); iter++)
{
cout << *iter << " ";
}

六:性能测试
#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include <stdio.h>
#include <cstring> #if _MSC_VER
#define snprintf _snprintf
#endif using namespace std; long get_a_target_long()
{
/******变量声明********/
long target = ;
/**********************/ cout << "targer (0~" << RAND_MAX << "):";
cin >> target;
return target;
} string get_a_target_string()
{
/******变量声明********/
long target = ;
char buf[];
/**********************/ cout << "targer (0~" << RAND_MAX << "):";
cin >> target; snprintf(buf, , "%d", target);
return string(buf);
} //与后面的比较函数中回调参数对应
int compareLongs(const void* l1, const void* l2)
{
return (*(long*)l1 - *(long*)l2);
} int compareStrings(const void* s1, const void* s2)
{
if (*(string*)s1 > *(string*)s2)
return ;
if (*(string*)s1 < *(string*)s2)
return -;
return ;
}
公共函数
/************************************************************************/
/*测试数组 */
/************************************************************************/
#include <array>
#include <iostream>
#include <algorithm>
#include <ctime>
#include <cstdlib> #define ASIZE 200000 //由于数组声明需要使用常量值,故在这里写死
//500000个long---4000000Byte---4M //数组Array测试
namespace jj01
{
void test_array()
{
cout << "\ntest_array()*******" << endl; /******变量声明:数组初始********/
array<long, ASIZE> arr; /******变量声明:记录时间********/
clock_t timeStart = clock(); //开始时间
for (long i = ; i < ASIZE; i++)
arr[i] = rand(); //0-32767,所以有重复 cout << "inti array use milli-seconds:" << (clock() - timeStart) << endl; //获取初始化数组耗时
cout << "array.size:" << arr.size() << endl; //获取数组大小
cout << "array.front:" << arr.front() << endl; //获取数组首元素
cout << "array.back:" << arr.back() << endl; //获取数组尾元素
cout << "array.data:" << arr.data() << endl; //获取数组首地址 /******变量声明:获取我们要查询的数********/
long target = get_a_target_long(); timeStart = clock(); //qsort和bsearch是C编译器自带的快速排序和二分查找算法
qsort(arr.data(), ASIZE, sizeof(long), compareLongs); /******变量声明:pItem是我们获取的返回的元素地址********/
long* pItem =
(long*)bsearch(&target, arr.data(), ASIZE, sizeof(long), compareLongs);
cout << "qsort()+bsearch(),milli-seconds:" << clock() - timeStart << endl;
if (pItem != NULL)
cout << "found:" << *pItem << endl;
else
cout << "not found!" << endl; random_shuffle(arr.begin(), arr.end()); //乱序 //STL排序查找算法
timeStart = clock(); sort(arr.begin(), arr.end());
/******变量声明:flag布尔型判断是否找到数据********/
bool flag =
binary_search(arr.begin(), arr.end(), target); cout << "sort()+binary_search(),milli-seconds:" << clock() - timeStart << endl;
if (flag != false)
cout << "found:" << *pItem << endl;
else
cout << "not found!" << endl; //使用find方法进行查找
timeStart = clock(); auto pI = find(arr.begin(), arr.end(), target); cout << "::find(),milli-seconds:" << clock() - timeStart << endl;
if (flag != false)
cout << "found:" << *pI << endl;
else
cout << "not found!" << endl;
}
}

07--STL序列容器(Array)的更多相关文章
- STL 序列容器
转自时习之 STL中大家最耳熟能详的可能就是容器,容器大致可以分为两类,序列型容器(SequenceContainer)和关联型容器(AssociativeContainer)这里介绍STL中的各种序 ...
- STL List容器
转载http://www.cnblogs.com/fangyukuan/archive/2010/09/21/1832364.html 各个容器有很多的相似性.先学好一个,其它的就好办了.先从基础开始 ...
- STL序列式容器学习总结
STL序列式容器学习总结 参考资料:<STL源码剖析> 参考网址: Vector: http://www.cnblogs.com/zhonghuasong/p/5975979.html L ...
- STL——序列式容器
一.容器概述与分类 1. STL容器即是将运用最广的一些数据结构实现出来.常用的数据结构有array, list, tree, stack, queue, hash table, set, map…… ...
- 《STL源码剖析》——第四章、序列容器
1.容器的概观与分类 所谓序列式容器,其中的元素都可序(ordered)[比如可以使用sort进行排序],但未必有序(sorted).C++语言本身提供了一个序列式容器array,STL另外再提供v ...
- STL常用序列容器
这里简要的记述一下STL常用容器的实现原理,要点等内容. vector vector是比较常用的stl容器,用法与数组是非类似,其内部实现是连续空间分配,与数组的不同之处在于可弹性增加空间,而arra ...
- STL基础--容器
容器种类 序列容器(数组,链表) Vector, deque, list, forward list, array 关联容器(二叉树),总是有序的 set, multiset根据值排序,元素值不能修改 ...
- [C++ STL] 各容器简单介绍
什么是STL? 1.STL(Standard Template Library),即标准模板库,是一个高效的C++程序库. 2.包含了诸多常用的基本数据结构和基本算法.为广大C++程序员们提供了一个可 ...
- 【Example】C++ STL 常用容器概述
前排提醒: 由于 Microsoft Docs 全是机翻.所以本文表格是我人脑补翻+审校. 如果有纰漏.模糊及时评论反馈. 序列式容器 序列容器是指在逻辑上以线性排列方式存储给定类型元素的容器. 这些 ...
- C++ STL vector容器学习
STL(Standard Template Library)标准模板库是C++最重要的组成部分,它提供了一组表示容器.迭代器.函数对象和算法的模板.其中容器是存储类型相同的数据的结构(如vector, ...
随机推荐
- [Alibaba-ARouter] 简单好用的Android页面路由框架
开发一款App,总会遇到各种各样的需求和业务,这时候选择一个简单好用的轮子,就可以事半功倍 前言 Intent intent = new Intent(mContext, XxxActivity.cl ...
- android使用百度地图最新sdk5.0后后代码混淆时,地图无法显示闪退问题
描述:刚开始遇到这个问题我一步一步去排除,最后发现在初始化地图的时候,代码混淆就有问题了, 问题描述:当跳显示地图的页面APP闪退, 解决对比: 1:对于老版本百度sdk:代码混淆时语句: -libr ...
- 测者的测试技术手册:Java中的null类型是测试不可超越的鸿沟
null是一个非常非常特殊的类型,对于每一个测试人员都要十分小心null的存在的可能性.同时null也让很多RD头疼,甚至连Java的设计者都成人null是一个设计失误.这篇文章,测者想聊聊这个让很多 ...
- C# 匿名对象(匿名类型)、var、动态类型 dynamic——实用之:过滤类属性、字段实用dynamic
例子 返回一个LIst<oject>类型 而oject含有 30个字段 而我只需要两个字段.这里实用dynamic 和 linq. 上代码: 注意select new {} 为匿名类型,这 ...
- python使用rabbitMQ介绍五(话题模式)
一.模式介绍 话题模式(Topic)基本思想和路由模式是一样的,只不过路由键支持模糊匹配,符号“#”匹配一个或多个词,符号“*”匹配不多不少一个词 话题模式相当于消息的模糊匹配,或者按照正则匹配.其中 ...
- Linux(三)——Unix&Linux 的基础命令
Linux(三)--Unix&Linux 的基础命令 快捷键 Ctl-A 光标移动到行首 Ctl-C 终止命令 Ctl-D 注销登录 Ctl-E 光标移动到行尾 Ctl-U 删除光标到行首的所 ...
- 移动端左右滑动问题-html与css解决
<!DOCTYPE html> <html> <head> <title>纯css实现左右滑动</title> <style type ...
- CMake与Make最简单直接的区别 [转]
写程序大体步骤为: 1.用编辑器编写源代码,如.c文件. 2.用编译器编译代码生成目标文件,如.o. 3.用链接器连接目标代码生成可执行文件,如.exe. 但如果源文件太多,一个一个编译时就会特别麻烦 ...
- EntityFramework Core进行读写分离最佳实践方式,了解一下(一)?
前言 本来打算写ASP.NET Core MVC基础系列内容,看到有园友提出如何实现读写分离,这个问题提的好,大多数情况下,对于园友在评论中提出的问题,如果是值得深究或者大多数同行比较关注的问题我都会 ...
- java.util.NoSuchElementException错误原因及解决方案
1.原因:没有控制语句导致的迭代器的越界,使得map中的数据无法传入reduce,从而无法把结果传入目标文件中. 在进行Mapreduce实例——WordCount实验时遇到的错误,开始以为是lib包 ...