STL算法——函数对象适配器

简介: STL算法——函数对象适配器

全部案例链接


https://download.csdn.net/download/weixin_45525272/12536637



函数适配器bind1st bind2nd


现在我有这个需求 在遍历容器的时候,我希望将容器中的值全部加上100之后显示出来,怎么做?


我们直接给函数对象绑定参数 编译阶段就会报错


for_each(v.begin(), v.end(), bind2nd(myprint(),100));


如果我们想使用绑定适配器,需要我们自己的函数对象继承binary_function或者 unary_function


根据我们函数对象是一元函数对象 还是二元函数对象


class MyPrint :public binary_function<int,int,void>
{
public:
  void operator()(int v1,int v2) const
  {
    cout << "v1 = : " << v1 << " v2 = :" <<v2  << " v1+v2 = :" << (v1 + v2) << endl;  
  }
};
1、函数适配器
void test01()
{
  vector<int>v;
  for (int i = 0; i < 10; i++)
  {
    v.push_back(i);
  }
  cout << "请输入起始值:" << endl;
  int x;
  cin >> x;
  for_each(v.begin(), v.end(), bind1st(MyPrint(), x));
  //for_each(v.begin(), v.end(), bind2nd( MyPrint(),x ));
}


总结: bind1st和bind2nd区别?


bind1st : 将参数绑定为函数对象的第一个参数


bind2nd : 将参数绑定为函数对象的第二个参数


bind1st bind2nd将二元函数对象转为一元函数对象


class GreaterThenFive:public unary_function<int,bool>
{
public:
  bool operator ()(int v) const
  {
    return v > 5;
  }
};
2、取反适配器
void test02()
{
  vector <int> v;
  for (int i = 0; i < 10;i++)
  {
    v.push_back(i);
  }
//  vector<int>::iterator it =  find_if(v.begin(), v.end(), GreaterThenFive()); //返回第一个大于5的迭代器
//  vector<int>::iterator it = find_if(v.begin(), v.end(),  not1(GreaterThenFive())); //返回第一个小于5迭代器
  自定义输入
  vector<int>::iterator it = find_if(v.begin(), v.end(), not1 ( bind2nd(greater<int>(),5)));
  if (it == v.end())
  {
    cout << "没找到" << endl;
  }
  else
  {
    cout << "找到" << *it << endl;
  }
  //排序  二元函数对象
  sort(v.begin(), v.end(), not2(less<int>()));
  for_each(v.begin(), v.end(), [](int val){cout << val << " "; });
}


not1 对一元函数对象取反


not2 对二元函数对象取反


void MyPrint03(int v,int v2)
{
  cout << v + v2<< " ";
}
3、函数指针适配器   ptr_fun
void test03()
{
  vector <int> v;
  for (int i = 0; i < 10; i++)
  {
    v.push_back(i);
  }
  ptr_fun( )把一个普通的函数指针适配成函数对象
  for_each(v.begin(), v.end(), bind2nd( ptr_fun( MyPrint03 ), 100));
}
4、成员函数适配器
class Person
{
public:
  Person(string name, int age)
  {
    m_Name = name;
    m_Age = age;
  }
  //打印函数
  void ShowPerson(){
    cout << "成员函数:" << "Name:" << m_Name << " Age:" << m_Age << endl;
  }
  void Plus100()
  {
    m_Age += 100;
  }
public:
  string m_Name;
  int m_Age;
};
void MyPrint04(Person &p)
{
  cout << "姓名:" <<  p.m_Name << " 年龄:" << p.m_Age << endl;
};
void test04()
{
  vector <Person>v;
  Person p1("aaa", 10);
  Person p2("bbb", 20);
  Person p3("ccc", 30);
  Person p4("ddd", 40);
  v.push_back(p1);
  v.push_back(p2);
  v.push_back(p3);
  v.push_back(p4);
  //for_each(v.begin(), v.end(), MyPrint04);
  //利用 mem_fun_ref 将Person内部成员函数适配
  for_each(v.begin(), v.end(), mem_fun_ref(&Person::ShowPerson));
//  for_each(v.begin(), v.end(), mem_fun_ref(&Person::Plus100));
//  for_each(v.begin(), v.end(), mem_fun_ref(&Person::ShowPerson));
}
void test05(){
  vector<Person*> v1;
  //创建数据
  Person p1("aaa", 10);
  Person p2("bbb", 20);
  Person p3("ccc", 30);
  Person p4("ddd", 40);
  v1.push_back(&p1);
  v1.push_back(&p2);
  v1.push_back(&p3);
  v1.push_back(&p4);
  for_each(v1.begin(), v1.end(), mem_fun(&Person::ShowPerson));
}


如果容器存放的是对象指针, 那么用mem_fun


如果容器中存放的是对象实体,那么用mem_fun_ref

相关文章
|
1月前
|
缓存 算法 Java
JVM知识体系学习六:JVM垃圾是什么、GC常用垃圾清除算法、堆内存逻辑分区、栈上分配、对象何时进入老年代、有关老年代新生代的两个问题、常见的垃圾回收器、CMS
这篇文章详细介绍了Java虚拟机(JVM)中的垃圾回收机制,包括垃圾的定义、垃圾回收算法、堆内存的逻辑分区、对象的内存分配和回收过程,以及不同垃圾回收器的工作原理和参数设置。
65 4
JVM知识体系学习六:JVM垃圾是什么、GC常用垃圾清除算法、堆内存逻辑分区、栈上分配、对象何时进入老年代、有关老年代新生代的两个问题、常见的垃圾回收器、CMS
|
1月前
|
算法 数据处理 C++
c++ STL划分算法;partition()、partition_copy()、stable_partition()、partition_point()详解
这些算法是C++ STL中处理和组织数据的强大工具,能够高效地实现复杂的数据处理逻辑。理解它们的差异和应用场景,将有助于编写更加高效和清晰的C++代码。
22 0
|
2月前
|
XML JavaScript 前端开发
学习react基础(1)_虚拟dom、diff算法、函数和class创建组件
本文介绍了React的核心概念,包括虚拟DOM、Diff算法以及如何通过函数和类创建React组件。
29 2
|
4月前
|
存储 监控 算法
(六)JVM成神路之GC基础篇:对象存活判定算法、GC算法、STW、GC种类详解
经过前面五个章节的分析后,对于JVM的大部分子系统都已阐述完毕,在本文中则开始对JVM的GC子系统进行全面阐述,GC机制也是JVM的重中之重,调优、监控、面试都逃不开的JVM话题。
130 8
|
3月前
|
算法
【Azure Developer】完成算法第4版书中,第一节基础编码中的数组函数 histogrm()
【Azure Developer】完成算法第4版书中,第一节基础编码中的数组函数 histogrm()
|
4月前
|
算法 Python
`scipy.optimize`模块提供了许多用于优化问题的函数和算法。这些算法可以用于找到函数的最小值、最大值、零点等。
`scipy.optimize`模块提供了许多用于优化问题的函数和算法。这些算法可以用于找到函数的最小值、最大值、零点等。
|
4月前
|
算法 安全 数据安全/隐私保护
支付系统---微信支付09------数字签名,现在Bob想要给Pink写一封信,信件的内容不需要加密,怎样能够保证信息的完整性,使用信息完整性的主要手段是摘要算法,散列函数,哈希函数,H称为数据指纹
支付系统---微信支付09------数字签名,现在Bob想要给Pink写一封信,信件的内容不需要加密,怎样能够保证信息的完整性,使用信息完整性的主要手段是摘要算法,散列函数,哈希函数,H称为数据指纹
|
4月前
|
算法 C++
STL算法大全
以上只是一部分STL算法的简单概述,每一个算法都有其特定的使用场景和规则,具体使用时需要参考相关文档或者教程进行深入理解和学习。
32 0
|
5月前
|
算法 vr&ar
技术好文共享:遗传算法解决函数优化
技术好文共享:遗传算法解决函数优化
|
5月前
|
算法 搜索推荐 C++
C++之STL常用算法(遍历、查找、排序、拷贝、替换、算数生成、集合)
C++之STL常用算法(遍历、查找、排序、拷贝、替换、算数生成、集合)