//1.标准库算法不仅可以应用于容器,还可以应用于内置数组,指针。

//2.大多数算法都定义在头文件algorithm中。标准库还在头文件numeric中定义了一组数值泛型算法。

//3.算法本身不会改变其操作对象的大小,但是通过插入迭代器,可以间接改变传入容器的大小。

//4.lambda表达式:
// A:一个lambda具有返回类型(必须由尾置返回),一个参数列表,一个函数体。可以定义在函数的内部。
// B:如果lambda的函数体包含任意return之外的语句,则其默认的返回值类型是void
// C:lambda的参数不能具有默认实参
// D:当编写了一个lambda后,编译器将该表达式翻译成一个未命名的类的未命名对象。在lambda产生的类中含有一个重载的函数调用运算符。
// E:默认情况下,lambda不能改变其捕获的变量,因此默认情况下lambda产生的类的函数调用运算符是const函数。如果lambda被声明为可变的时候(使用mutable修饰),则调用运算符就不是const的了。
// F:通过值捕获的变量被拷贝到lambda中,此种lambda产生的类必须为每个值捕获的变量建立对应的数据成员,同时创建构造函数令其使用捕获的变量的当前值来初始化数据成员,此初始化过程发生在lambda声明时而非调用时。
// G:通过引用捕获的变量将由程序保证lambda执行的时候引用所引用的对象确实存在。
// H:类的常量成员函数中的this的类型类似于:const A *const this;此类中存在指针成员int *pValue和引用类型int &valueCopy。则在常量成员函数中,pValue的类型为:int *const pValue; valueCopy的类型为:int &const valueCopy;
// 虽然pValue和valueCopy本身不能被改变,但是*pValue可以改变,valueCopy所引用的对象可以通过valueCopy进行改变。所以在非mutable的lambda中依然可以通过引用捕获改变被引用对象的值。
// I:隐式捕获的方式:&代表引用捕获,=代表值捕获。可以进行混用,但是捕获列表的第一个元素必须是&或者=,且显示捕获的变量的捕获方式必须与隐式捕获方式不同。
// J:默认情况下,对于一个值拷贝的变量,lambda不会改变其值。如果我们希望改变一个被捕获的的变量的值,可以在参数列表后使用关键字mutable。
// K:对于那种只在一两个地方使用的简单操作,lambda表示式是最有用的。当一个操作需要很多语句才能完成,那么最好使用函数。 //5.bind:接受一个可调用对象来生成一个新的可调用对象。其一般搭配占位符使用。占位符(_1到_10)声明在命名空间placeholders,其本身又声明在std中。定义在头文件functional中。 //6.标准库的ref()和cref(),前者返回被调用对象的引用,后者返回被调用对象的const引用。均定义在头文件functional中。 //7.插入迭代器:
// 被绑定在容器上,用于向容器插入元素。
// back_inserter:创建一个使用push_back的迭代器。
// front_inserter:创建一个使用push_front的迭代器。
// inserter:创建一个使用insert的迭代器,接受第二个参数为指向容器的迭代器,元素将插入到此迭代器之前,被创建的迭代器将一直指向其第二个参数。当不是通过此迭代器改变了容器的元素后,此函数创建的迭代器会失效。
// 对于插入迭代器:*it, ++it, it++操作均存在,但是都不对it做任何事情,只是返回it
// 均定义在头文件iterator中,使用时候需要包含命名空间std
using std::back_insert_iterator;
using std::front_insert_iterator;
using std::insert_iterator; deque<unique_ptr<char[]>> deStr;
back_insert_iterator<deque<unique_ptr<char[]>>> it_b= back_inserter(deStr);
it_b = (unique_ptr<char[]>)new char[]();
it_b = (unique_ptr<char[]>)new char[](); front_insert_iterator<deque<unique_ptr<char[]>>> it_f = front_inserter(deStr);
it_f = (unique_ptr<char[]>)new char[]();
it_f = (unique_ptr<char[]>)new char[](); insert_iterator<deque<unique_ptr<char[]>>> it_i = inserter(deStr, deStr.begin() + );
it_i = (unique_ptr<char[]>)new char[]();
it_i = (unique_ptr<char[]>)new char[]();
//deStr中的元素的大小:1 5 4 2 10 9 //8.反向迭代器:
// 递增递减的含义会颠倒过来。基于这一点,在使用算法的时候可以从后向前处理容器的元素。
// reserve_iterator的base成员可以将反向迭代器转为对应的普通迭代器(反向迭代器所指的下一个元素) //9.算法所要求的迭代器的类别:
// 输入迭代器:只读,不写,单遍扫描,只能递增
// 输出迭代器:只写,不读,单遍扫描,只能递增
// 前向迭代器:可读写,多遍扫描,只能递增
// 双向迭代器:可读写,多遍扫描,可递增递减
// 随机访问迭代器:支持所有迭代器运算
// 输入迭代器:必须支持 == != ++ -> 运算符, *操作只会出现在=右侧。输入迭代器不能保证输入迭代器的状态可以保存,即只支持单遍扫描。算法find要求其迭代器是输入迭代器
// 输出迭代器:必须支持 ++ 运算符, *操作只会出现在=左侧。我们只能向一个输出迭代器输出一次。算法copy的第三个参数就是输出迭代器。
// 前向迭代器:可以读写元素,这类迭代器只能在序列中沿一个方向移动,此类迭代器支持输入输出迭代器的所有操作,而且可以对一个元素进行多次读写,可以保存前向迭代器的状态,支持多遍扫描。
// 双向迭代器:可以正向反向读写序列中的元素,支持前向迭代器的所有操作,支持--操作。算法reverse()要求双向迭代器,除了forward_list外的容器都提供符合此要求的迭代器
// 随机访问迭代器:提供常量时间内访问任意元素的能力,支持双向迭代器的所有操作, 支持 < <= > >= + += - -= - [] 运算符。算法sort要求随机访问迭代器。array deque string vector 内置数组指针都是此类迭代器 //10.链表本身的算法比通用版本的算法的性能高很多。
// list1.merge(list2):将list2的元素合并入list1,两个链表必须都是有序的。接受第二个参数谓语来自定义比较操作
// list1.remove(val):将给定值删除,有一个remove_if的版本,将删除令一元谓语成立的元素。
// list.reverse():翻转list中的元素
// list.sort():使用<或者给定的操作来排序元素
// list.unique():删除同一值的连续拷贝,可以接受二元谓语。
// list的splice和splice_after系列函数:都是将给定的序列剪切到指定的迭代器前或者后的操作。 splice [splaɪs] n. 接合

C++Primer 第十章的更多相关文章

  1. C++ Primer : 第十章 : 泛型算法 之 lambda表达式和bind函数

    一.lambda表达式 lambda表达式原型: [capture list] (parameter list) -> retrue type { function body } 一个lambd ...

  2. C++ Primer : 第十章 : 泛型算法 之 只读、写和排序算法

    大多数算法都定义在<algorithm>头文件里,而标准库还在头文件<numeric>里定义了一组数值泛型算法,比如accumulate. ●  find算法,算法接受一对迭代 ...

  3. [c++] Associative Containers

    关联容器 和 顺序容器 的本质差别在于: 关联容器通过键(key)存储和读取元素,而顺序容器则通过元素在容器中的位置顺序存储和访问元素. Reference: http://www.cnblogs.c ...

  4. 关于竞赛大佬常用的 static const auto _ = []() 用法解析

    前言 在刷Leetcode的时候发现很多运算速度极快的代码都有这一段,所以研究一下. static const auto _ = []() { ios::sync_with_stdio(false); ...

  5. 【C++】《C++ Primer 》第十章

    第十章 泛型算法 一.概述 因为它们实现共同的操作,所以称之为"算法".而"泛型",指的是它们可以操作在多种容器类型上. 泛型算法并不直接操作容器,而是遍历由两 ...

  6. C++ Primer :第十章 :泛型算法之再探迭代器以及其他算法

    除了为每个容器定义的迭代器之外,标准库在头文件<iterator>还定义了额外集中迭代器, 包括: 插入迭代器,这些迭代器被绑定到一个容器上,可以向容器插入元素. 流迭代器,    这些迭 ...

  7. C primer plus 读书笔记第十章

    这一章的标题是数组和指针.指针是C语言的精髓所在,而数组的概念和指针又息息相关,所以放在一起讲. 1.数组 主要内容有:1.1.数组初始化.1.2.指定初始化.1.3.数组赋值.1.4.数组边界.1. ...

  8. 《C++ Primer Plus 6th》读书笔记 - 第十章 对象和类

    1. 过程性编程和面向对象编程 2. 抽象和类 1. 使用类对象的程序都可以直接访问公有部分,但只能通过公有成员函数(或友元函数)来访问对象的私有成员 2. 可以在类声明之外定义成员函数,并使其成为内 ...

  9. C++ Primer Plus学习:第十章

    过程性编程和面向对象编程 面向对象编程(OOP)的特性: 抽象 封装和数据隐藏 多态 继承 代码的可重用性 抽象和类 类是一种将抽象转化为用户定义类型的C++工具,它将数据表示和操纵数据的方法合成一个 ...

随机推荐

  1. php--某个字符在字符串中的位置比较

    <?php $haystack = 'helloe'; $needle = 'e'; $pos = stripos($haystack, $needle); echo "\n" ...

  2. CC2540 USB DONGLE 使用 BTool 调试BLE 说明

    一.Btool软件界面介绍 首先您要将USBDONGLE插入电脑的USB口,然后打开双击打开Btool软件,打开后如下图所示: 在安装驱动的教程中,我们已经记住了我们的USB DONGLE的串口号,在 ...

  3. Java高级之类结构的认识

    本文来自http://blog.csdn.net/liuxian13183/ ,引用必须注明出处! Java体系包括,各种版本的虚拟机,可执行文件,各种第三方类库,Java API类库,Java语言 ...

  4. There is no tracking information for the current branch

    There is no tracking information for the current branch. Please specify which branch you want to mer ...

  5. Windows下一个比较完美的线程池实现(使用线程池实现的Http上传下载实现)

    http://blog.csdn.net/fishjam/article/details/8632049 http://download.csdn.net/user/fishjam

  6. 使用node.js的bodyParser中间件读取post数据解析

    昨天我们使用的网关转发数据时出了点问题! 情景是这样的,另一方以Post的形式向我的node.js服务推送JSON数据.但是使用bodyParser中间件后,在req.body中拿不到任何信息. 代码 ...

  7. [LeetCode] Edit Distance(很好的DP)

    Given two words word1 and word2, find the minimum number of steps required to convert word1 to word2 ...

  8. Codeforces Round #367 (Div. 2)---水题 | dp | 01字典树

    A.Beru-taxi 水题:有一个人站在(sx,sy)的位置,有n辆出租车,正向这个人匀速赶来,每个出租车的位置是(xi, yi) 速度是 Vi;求人最少需要等的时间: 单间循环即可: #inclu ...

  9. Swift-06-闭包

    看完记不住,只好继续抄课文. 如果某个存储型属性的默认值需要特别的定制或者准备,就可以使用闭包或者全局函数来为其属性提供定制的默认值.每当某个属性所属的新类型实例创建时,对应的闭包或者函数会被调用,而 ...

  10. Intellij IDEA @Override 标红

    Intellij IDEA 升级到15之后,之前那些@Override 的都标红,提示@Override is not allowed when implement interface method ...