• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >C语言 > C++之Boost::array用法简介

C++之Boost::array用法简介

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-28

通过本文主要向大家介绍了c++ boost,c++ boost库,boost c++ libraries,c++ array,c++中string的用法等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

本文实例讲述了c++里支持静态数组的容器:boost.array。分享给大家供大家参考。具体分析如下:

很多C++程序员都认为boost.array很有可能出现在下一代标准库里。对于boost.array的用法有一个基本的了解是很有必要的。

1. 为什么我们需要固定大小的数组的容器

首先,固定大小的数组还是很常见的,虽然stl提供了vector,但是vector作为动态可增长的数组,比静态数组多了一点开销,这在一些人看来是无法忍受的。c++里也需要提供固定大小容量的数组容器,当然,性能可以和普通数组想媲美。

boost.array应此需求而生。

boost.array 实现了大部分但不是全部的“可逆容器(reversable container)”的需求。array 不是一个 STL 可逆容器的原因在于:

① 没有提供构造函数。
② 元素可能有一个不确定的初始值。
③ swap() 不具有常量复杂度。
④ size() 基于第二个模板参数的类型,总是恒定的。
⑤ 容器不提供分配器支持。

它没有实现“序列”的需求(具体可参见 C++ 标准的 23.1.1, [lib. sequence.reqmts]),但以下这些除外:

① 提供了 front() 和 back()。
② 提供了 operator[] 和 at()。

2. 头文件和相关成员函数声明:
Reference
Header <boost/array.hpp>
Class template array(类模板 array)
array 公有的 构造/拷贝/析构

template<typename U> array& operator=(const array<U, N>& other);

array 迭代器支持:

1.iterator begin();
const_iterator begin() const;

返回:

位于第一个元素的迭代器

抛出:

不抛出异常

2.iterator end();
const_iterator end() const;

返回:

位于最后一个元素之后位置的迭代器

抛出:

不抛出异常

array 反向迭代器支持:

1.reverse_iterator rbegin();
const_reverse_iterator rbegin() const;

返回:

位于反向迭代的第一个元素的反向迭代器

2.reverse_iterator rend();
const_reverse_iterator rend() const;

返回:

位于反向迭代的最后一个元素之后位置的反向迭代器

array 容量:

1.size_type size();

返回:

N

2.bool empty();

返回:

N==0

抛出:

不抛出异常

3.size_type max_size();

返回:

N

抛出:

不抛出异常

array 元素访问:

1.reference operator[](size_type i);
const_reference operator[](size_type i) const;

Requires:

i < N

返回:

索引为 i 的元素

抛出:

不抛出异常。

2.reference at(size_type i);
const_reference at(size_type i) const;

返回:

索引为 i 的元素

抛出:

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • C++ boost 时间与日期处理详细介绍
  • C++中Boost库裁剪与其应用详解
  • C++之BOOST字符串查找示例
  • C++之Boost::array用法简介
  • C++之boost::array的用法

相关文章

  • 2017-05-28c语言打印输出双引号的方法示例
  • 2017-05-28VC++在TXT文件指定位置追加内容的方法
  • 2017-05-28使用map实现单词转换的实例分析
  • 2017-05-28C语言中isdigit()函数和isxdigit()函数的用法
  • 2017-05-28C++实现广度优先搜索实例
  • 2017-05-28C++ sizeof 实例解析
  • 2017-05-28C语言二分查找算法及实现代码
  • 2017-05-28C语言宏定义使用分析
  • 2017-05-28C语言指针的长度和类型深入分析
  • 2017-05-28C语言中 “_at()” 特殊地址定位详解

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • 浅谈C#互操作的内存溢出问题
    • C++ COM编程之接口背后的虚函数表
    • C++ operator关键字(重载操作符)的用法详解
    • C++二分查找(折半查找)算法实例详解
    • strncpy与snprintf 的用法比较
    • C语言中改变目录的相关操作函数详解
    • 解析C++编程中如何使用设计模式中的状态模式结构
    • 二叉树前序遍历的非递归算法
    • 浅谈c/c++中使用指针需要注意的问题
    • C语言中的fscanf()函数与vfscanf()函数使用

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有