C++泛型和算法

Posted LarryZeal

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C++泛型和算法相关的知识,希望对你有一定的参考价值。

看书的速度终于慢了下来,倒不是难于理解,而是需要理解的东西有点多。

 

吐槽下C++Primer这本书,不少地方都是用抽象的语言进行介绍!

拜托,你这是介绍,不是总结!

像容器适配器那里:

“本质上,适配器是使一事物的行为类似于另一事物的行为的一种机制。容器适配器让一种已存在的容器类型采用另一种 不同的抽象类型的工作方式实现。”

直接说转换接口不是更通俗易懂吗???

>>>>>>>>>>>>>>>>>吐槽结束>>>>>>>>>>>>>>>>>>>>>

 

泛型,generic,这个概念比较抽象。当初学Java的时候对这个词就不知所云,不过看过例子就明白了。--纠结于汉语的博大精深~

C++中的泛型也是类似的概念,虽然还没看到后面的部分。

 

算法,书中特指的是标准库自带的算法,据说100多种,大多用于操作容器(将IO流也看作某种序列)。

基本上,算法应用于一段范围内的元素上,而算法又独立于容器,所以算法大多是通过一对迭代器来遍历并操作元素。

 

所以要求迭代器能自增自减、能解引用、能比较、能标识结尾,有的还要求容器的元素类型支持比较等---这与具体的算法有关,就不一一细说了。

 

注意,多数时候不要求类型匹配,只要元素可以比较即可。

书中罗列的函数

find(b, e, val); //范围内查找元素,如找到,返回该元素的迭代器,否则返回超出末端迭代器。

find_if(b, e, func); //范围内查找满足函数func的元素,返回第一个满足元素的迭代器或超出末端迭代器。


accumulate(b, e, init_val); //累加范围内的元素,再加上init_val。init_val的意义在于指明类型。务必注意字符串字面值和string的区别,这里不会自动转换!


find_first_of(b1, e1, b2, e2); //从第一个范围内查找第二范围内出现的任意的元素。可用于统计公有元素数量或元素(见例子)


fill(b, e, val); //范围内的元素用val覆盖。

fill_n(iter, count, val); //从iter开始,用val覆盖count长度范围内的元素。--要求iter+count在有效范围内!!!


//迭代器适配器

back_inserter(c); //写入的时候,底层调用push_back

front_inserter(c); //写入的时候,底层调用push_front。所以vector不行。

inserter(c); //写入的时候,底层调用insert。

//迭代器适配器返回包装后的迭代器,方法一样,但操作不同。如:

fill_n(back_inserter(c), count, val); //这样会在尾部追加count个val。


copy(b, e, iter); //将范围内的元素复制到iter后面。


//算法的_copy版本!对输入元素进行处理,但不修改原元素,而是创建一个副本。

replace(b, e, v1, v2); //用v2替换范围内的v1。

replace_copy(b, e, iter, v1, v2); //用v1替换范围内的v2,并保存到iter处。be范围内不变。--需要指定目标迭代器


sort(b, e); //对范围内的元素进行排序

stable_sort(b, e, func); //其实就是懒排序,例如通过长度排序时,只要相邻的元素长度一致,则相对位置不会改变。

unique(b, e); //将范围内的元素去重后 覆盖范围内前面的元素,返回没被覆盖的第一个元素迭代器。


count(b, e, val); //

count_if(b, e, func); //

 

以上是关于C++泛型和算法的主要内容,如果未能解决你的问题,请参考以下文章

java 泛型和object比较

Swift 2023:强调并发泛型和C++互操作性,开发Swift解析器

c++ 泛型 模板继承问题

0513 泛型和学生信息

0513 泛型和学生信息

泛型和泛型集合