9. OOP(面向对象编程)和GP(泛型编程)

发布时间 2023-06-29 01:32:29作者: C++杀我

OOP和GP区别

  • OOP将datas和methods关联在一起,而GP却是将两者分开,也就是容器自己搞自己的, 算法自己搞自己的, 然后两者通过迭代器(Iterator)联系起来。Algorithms通过Iterators确定操作范围,并通过Iterators取用Container元素。

p1

                                            p2

                                              p3

   然后抛出一个很关键的问题:为什么list不能用全局的sort()函数呢???

   答:p3中sort的source code告诉我们,在标准库中,满足(first+(last - first) / 2) 这种运算规则的必须是 RandomAccessIterator -- 随机访问迭代器。

       例如vector,array等它们的存储空间都是连续的,可以方便“跳跃式”的访问某一个元素,比如+5就是访问后面第五个元素,-10就是访问前面第10个元素;

     而list这种链式存储的容器显然是没法做到这点的,因为list的内存空间不是连续的。

 

 

 

 

  其他内容:

                                              p4