9. OOP(面向对象编程)和GP(泛型编程)
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
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· winform 绘制太阳,地球,月球 运作规律
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人