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

上海装修找哪家公司好百度seo工作室

上海装修找哪家公司好,百度seo工作室,全球游戏制作公司排名,手机网站模板 餐饮本篇博客是学习过程中的笔记、思考和总结。原文链接: 3 泛型编程风格 Generic Programming3.1 指针的算术运算3.2 了解 Iterator(泛型指针)3.3 所有容器的共通操作 3 泛型编程风格 Generic Programming STL的主要组件:Container&…

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

  • 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.tj-hxxt.cn/news/124874.html

相关文章:

  • 如何做楼盘网站怎么创建自己的网站平台
  • 霸州有做滤芯网站的吗刷赞网站推广永久
  • 国外有哪些网站是做弱电的品牌宣传推广方案
  • 蔬菜网站建设seo排名优化代理
  • 青岛网站设计软件seo网络推广公司排名
  • style wordpress 主题东莞百度seo推广公司
  • 网站备案截图投百度做广告效果怎么样
  • 专业做网站哪家正规网站建设服务商
  • 山西网站建设营销qq软文推广文章案例
  • 有什么手机做网站的石家庄谷歌seo
  • 新手做亚马逊要逛哪些网站牛奶软文广告营销
  • 网站免费正能量下载淘宝站内推广方式有哪些
  • 中国商标网商标查询官方网站徐州seo外包
  • 河北专业做网站中国优化网
  • 支付宝手机网站支付二维码怎么做seo站长助手
  • wordpress 链接新窗口sem优化托管公司
  • 高碑店建设局网站百度指数的数据来源
  • 各类网站网站建设的目标是什么意思网络优化初学者难吗
  • jquery mobile移动网站开发 pdf网络营销策划书论文
  • 网站百度权重没有数据品牌策划方案怎么写
  • 网站建设公司年终总结网络视频营销策略有哪些
  • 电子商务网站建设分析论文网络营销策略的概念
  • 做啊网站seo推广和百度推广的区别
  • 化妆品网站设计思路怎么做推广赚钱
  • 网站开发后台需要哪些技术雅诗兰黛网络营销策划书
  • 东莞网站开发营销广州网站推广软件
  • 西安头条今日头条新闻百度推广seo优化
  • 日本网站开发工作网络营销的定义
  • java做网站下载图片友情链接翻译
  • 银川做企业网站网站推广方式