当前位置: 首页 > news >正文

Essential C++【读书笔记 思考总结】

本篇博客是学习过程中的笔记、思考和总结。原文链接:

  • 3 泛型编程风格 Generic Programming
    • 3.1 指针的算术运算
    • 3.2 了解 Iterator(泛型指针)
    • 3.3 所有容器的共通操作

3 泛型编程风格 Generic Programming

STL的主要组件:Container,generic algorithm。

顺序容器:顺序迭代访问。
关联容器:通过key访问。

map:key/value,key用来查找,value用来存储数据。
set:只有key。

通过 function template 实现 generic algorithm。
通过iterator 实现 Container 无关。
通过 template 实现 Container 元素类型无关。

3.1 指针的算术运算

vector 中查找元素:

#include <iostream>
#include <vector>using namespace std;void myFind(const vector<int>& vec, const int & value)
{for (int ix = 0; ix < vec.size(); ++ix){if (value == vec[ix]){cout << "find success:" <<vec[ix] << endl;return;}}cout << "find fail" << endl;
}int main()
{vector<int> vi;vi.push_back(1);vi.push_back(2);vi.push_back(3);myFind(vi, 2);return 0;
}

运行结果:

想办法让这个函数不仅可以处理整数,更可以处理任何类型——前提是该类型定义有equality(相等)运算符。

#include <iostream>
#include <vector>
#include <string>using namespace std;template<typename elemType>
void myFind(const vector<elemType>& vec, const elemType & value)
{for (int ix = 0; ix < vec.size(); ++ix){if (value == vec[ix]){cout << "find success:" <<vec[ix] << endl;return;}}cout << "find fail" << endl;
}int main()
{vector<int> vi;vi.push_back(1);vi.push_back(2);vi.push_back(3);myFind(vi, 2);vector<string> vs;vs.push_back("11");vs.push_back("22");vs.push_back("33");string s1 = "22";myFind(vs, s1);return 0;
}

让一个函数同时可以处理vector与array内的任意类型元素——当然该类型的equality运算符皆已定义。

#include <iostream>
#include <vector>
#include <string>
#include <iterator> using namespace std;template<typename elemType>
void myFind(const elemType* first, const elemType* last, const elemType& value) // 重命名为myFind
{if (!first || !last)return;for (; first != last; ++first){if (*first == value){cout << "find success:" << *first << endl;return;}}cout << "find fail" << endl;
}int main()
{int array[5] = { 1,2,3,4,5 };myFind(array, array + 5, 1);vector<int> vi;vi.push_back(11);vi.push_back(22);vi.push_back(33);myFind(vi.data(), vi.data() + vi.size(), 22);vector<string> vs;vs.push_back("111");vs.push_back("222");vs.push_back("333");string s1 = "333";myFind(vs.data(), vs.data() + vi.size(), s1);return 0;
}

数组的函数传参和函数返回,只有数组的第一个元素地址会被传递。

下标操作:起始地址 +索引 产生新地址,新地址提领获取对象。

指针算术运算中,需要考虑指针类型。

问题:如何扩展 myFind()的功能,令它也能支持标准库所提供的 list 类别?
通过抽象,封装底层指针操作,一个 find实现所有容器的查找功能。

3.2 了解 Iterator(泛型指针)

如何取得iterator呢?
标准容器begin()函数,返回指向第一个元素的iterator。
标准容器end()函数,会返回指向最后一个元素的下一位置的iterator。

#include <iostream>
#include <vector>
#include <string>
#include <iterator>
#include <list>using namespace std;template<typename IteratorType, typename elemType>
IteratorType myFind(IteratorType first, IteratorType last, const elemType& value) // 重命名为myFind
{for (; first != last; ++first){if (*first == value){cout << "find success:" << *first << endl;return first;}}cout << "find fail" << endl;return last;
}int main()
{int array[5] = { 1,2,3,4,5 };myFind(array, array + 5, 1);vector<int> vi;vi.push_back(11);vi.push_back(22);vi.push_back(33);// 使用begin和end函数来调用myFindmyFind(vi.begin(), vi.end(), 22);vector<string> vs;vs.push_back("111");vs.push_back("222");vs.push_back("333");string s1 = "333";// 使用begin和end函数来调用myFindmyFind(vs.begin(), vs.end(), s1);list<string> ls;ls.push_back("1111");ls.push_back("2222");ls.push_back("3333");ls.push_back("4444");string s2 = "4444";myFind(ls.begin(), ls.end(), s2);return 0;
}

现在的 myFind支持一对指针或一对容器的迭代器,同时支持 array,list,vector,有了更大的通用性。

问题:如果容器元素不支持相等运算符,或者用户想用其他条件find,如何增加弹性?

3.3 所有容器的共通操作

  • ==
  • !=
  • =
  • empty()
  • size()
  • clear()
  • begin()
  • end()
  • insert()
  • erase()
http://www.lryc.cn/news/174203.html

相关文章:

  • 深度学习实战基础案例——卷积神经网络(CNN)基于Xception的猫狗识别|第2例
  • Linux Systemd 配置开机自启
  • 华为云云耀云服务器L实例评测|轻量级应用服务器对决:基于 fio 深度测评华为云云耀云服务器L实例的磁盘性能
  • 卸载Visual Studio 2010学习版 —— 卸载VCExpress
  • react的状态管理简单钩子方法
  • 【Git】轻松学会 Git:深入理解 Git 的基本操作
  • 什么是HTTP头部(HTTP headers)?
  • SpringCloud Alibaba 入门到精通 - Sentinel
  • 【深度学习实验】前馈神经网络(三):自定义多层感知机(激活函数logistic、线性层算Linear)
  • HJ68 成绩排序
  • FPGA——UART串口通信
  • 华为云Stack的学习(七)
  • 安装k8s集群
  • C++中编写没有参数和返回值的函数
  • SWC 流程
  • 怒刷LeetCode的第10天(Java版)
  • java框架-Springboot3-场景整合
  • 在Bat To Exe Converter,修改为当异常结束或终止时,程序重新启动执行
  • PythonWeb服务器(HTTP协议)
  • Northstar 量化平台
  • c语言进阶部分详解(经典回调函数qsort()详解及模拟实现)
  • win下 lvgl模拟器codeblocks配置
  • Quartus出租车计价器VHDL计费器
  • 浅谈单元测试:测试和自动化中的利用
  • 深度详解Java序列化
  • Linux下的网络编程——B/S模型HTTP(四)
  • Go语言入门篇
  • 基于springboot+vue的青年公寓服务平台
  • Spring-ImportSelector接口功能介绍
  • YOLOv5如何训练自己的数据集