zoukankan      html  css  js  c++  java
  • 泛型算法

    C++ 标准化过程做出的更重要的贡献之一是:创建和扩展了标准库。
    容器和算法库是标准库的基础。标准库定义了超过一百个算法。
    幸运的是,这些算法具有相同的结构,使它们更易于学习和使用。

    算法与类型无关:
    它们通常在一个元素序列上操作,这些元素可以存储在标准库容器类型、内置数组甚至是生成的序列(例如读写流所生成的序列)上。

    算法基于迭代器操作,从而实现类型无关性。大多数算法使用一对指定元素范围的迭代器作为其头两个实参。
    其他的迭代器实参包括指定输出目标的输出迭代器,或者用于指定第二个输入序列的另一个或一对迭代器。

    迭代器可通过其所支持的操作来分类。标准库定义了五种迭代器类别:
    输入、输出、前向、双向和随机访问迭代器。
    如果一个迭代器支持某种迭代器类别要求的运算,则该迭代器属于这个迭代器类别。

    正如迭代器根据操作来分类一样,算法的迭代器形参也通过其所要求的迭代器操作来分类。
    第一种模式只需要读取其序列的算法通常只要求输入迭代器的操作。
    而写目标迭代器的算法则通常只要求输出迭代器的操作,依此类推。

    第二种模式查找某个值的算法通常提供第二个版本,用于查找使谓词函数返回非零值的元素。
    对于这种算法,第二个版本的函数名字以 _if 后缀标识。
    类似地,很多算法提供所谓的复制版本,将(修改过的)元素写到输出序列,而不是写回输入范围。
    这种版本的名字以 _copy 结束。

    第三种模式是考虑算法是是否对元素读、写或者重新排序。算法从不直接改变它所操纵的序列的大小。
    (如果算法的实参是插入迭代器,则该迭代器会添加新元素,但算法并不直接这么做。)
    算法可以从一个位置将元素复制到另一个位置,但不直接添加或删除元素。

     

  • 相关阅读:
    [转]项目需求范围管理
    JavaScript 王者归来
    [转]大文件上传组件
    [转]使用vs2005自带的sql2005 express
    JS判断Caps Lock
    [转]Web项目管理思考
    [转]JS严格验证身份证
    两分钟用C#搭建IE BHO勾子, 窃取密码
    asp.net性能提升十个方法(Microsoft)
    [转]Asp.net 将js文件打包进dll 方法
  • 原文地址:https://www.cnblogs.com/yshl-dragon/p/3185790.html
Copyright © 2011-2022 走看看