c++学习笔记-提高篇-STL-函数对象

目录

一、函数对象

二、函数对象使用

三、谓词

1、概念

2、一元谓词

3、二元谓词

插入一条sort函数源码

四、内建函数对象

1.基本概念

2、算数仿函数

3、关系仿函数

4、逻辑仿函数


一、函数对象

函数对象概念

(1)重载函数调用操作符的类,其对象常称为函数对象

(2)函数对象使用重载的()时,行为类似函数调用,也叫仿函数

本质:

函数对象(仿函数)是一个类,不是一个函数

二、函数对象使用

特点:

  • 函数对象在使用时,可以像普通函数那样调用,可以有参数,可以有返回值
  • 函数对象超出普通函数的概念,函数对象可以有自己的状态
  • 函数对象可以作为参数传递
#include<iostream>
using namespace std;/*函数对象(仿函数)
函数对象在使用时,可以像普通函数那样调用,可以有参数,可以有返回值
函数对象超出普通函数的概念,函数对象可以有自己的状态
函数对象可以作为参数传递
*/class MyAdd
{
public:int operator()(int v1, int v2){return v1 + v2;}
};//1、函数对象在使用时,可以像普通函数那样调用,可以有参数,可以有返回值
void test01()
{MyAdd myadd;cout << myadd(10, 10) << endl;
}//2、函数对象超出普通函数的概念,函数对象可以有自己的状态
class MyPrint
{
public:MyPrint(){this->count = 0;}void operator()(string test){cout << test << endl;count++;}int count;   //内部自己状态
};void test02()
{MyPrint myprint;myprint("hello world");myprint("hello world");myprint("hello world");myprint("hello world");myprint("hello world");cout << "MyPrint调用次数为:" << myprint.count << endl;}//3、函数对象可以作为参数传递
void doPrint(MyPrint& mp, string test)
{mp(test);
}void test03()
{MyPrint myPrint;doPrint(myPrint, "Hello c++");
}int main()
{//test01();//test02();test03();system("pause");return 0;}

三、谓词

1、概念

  • 返回bool类型的仿函数称为谓词
  • 如果operator()接受一个参数,那么叫做一元谓词
  • 如果operator()接受两个参数,那么叫做二元谓词

2、一元谓词

operator()接受一个参数

示例:

#include<iostream>
using namespace std;#include<vector>
#include<algorithm>
//仿函数 返回值类型是bool数据类型,称为谓词
//一元谓词class GreaterFive
{
public:bool operator()(int val){return val > 5;}
};void test01()
{vector<int>v;for (int i = 0; i < 10; i++){v.push_back(i);}//查找容器中有没有大于5的数字//GreaterFive()是匿名的函数对象vector<int>::iterator it = find_if(v.begin(), v.end(), GreaterFive());if (it == v.end()){cout << "未找到" << endl;}else{cout << "找到了大于5的数字为:" << *it << endl;}
}int main()
{test01();system("pause");return 0;
}

3、二元谓词

operator()接受两个参数

示例:

#include<iostream>
using namespace std;
#include<vector>
#include<algorithm>
//二元谓词class myCompare
{
public:bool operator()(int v1, int v2){return v1 > v2;}
};void test01()
{vector<int> v;v.push_back(10);v.push_back(40);v.push_back(30);v.push_back(20);v.push_back(50);sort(v.begin(),v.end());//默认排序从小到大for (vector<int>::iterator it = v.begin(); it != v.end(); it++){cout << *it<<"  ";}cout << endl;//使用函数对象  改变算法策略,变为排序规则为从大到小  Pred就是谓词sort(v.begin(), v.end(), myCompare());cout << "------------------------------" << endl;for (vector<int>::iterator it = v.begin(); it != v.end(); it++){cout << *it << "  ";}cout << endl;}int main()
{test01();system("pause");return 0;
}

插入一条sort函数源码

sort函数两个重载版本如下图

  • 第一个重载版本是

_CONSTEXPR20 void sort(const _RanIt _First, const _RanIt _Last, _Pr _Pred)

参数1和参数2为迭代器表示的区间范围,参数3“_Pred”是谓词

  • 第二个重载版本是

_CONSTEXPR20 void sort(const _RanIt _First, const _RanIt _Last)

参数1和参数2为迭代器表示的区间范围

四、内建函数对象

1.基本概念

(1)概念:STL内建了一些函数对象

(2)分类

  • 算数仿函数
  • 关系仿函数
  • 逻辑仿函数

(3)用法

  • 这些仿函数产生的对象,用法和一般函数完全相同
  • 使用内建函数对象,需要引用头文件“#include<functional>”

2、算数仿函数

(1)功能描述

  • 实现四则运算
  • 其中negate是一元运算,其他都是二元运算

(2)仿函数原型

  • template<class T> T plus<T>                 //加法仿函数
  • template<class T> T minus<T>              //减法仿函数
  • template<class T> T multiplies<T>        //乘法仿函数
  • template<class T> T divides<T>            //除法仿函数
  • template<class T> T modulus<T>          //取模仿函数
  • template<class T> T negate<T>            //取反仿函数

(3)示例:加法、取反的使用

#include<iostream>
#include<functional>   //使用STL内建的函数对象 头文件
using namespace std;//内建函数对象  算数仿函数//nagete  一元仿函数  取反仿函数
void test01()
{negate<int>n;cout << n(50) << endl;
}//plus    二员仿函数  加法
void test02()
{plus<int>p;  //注意此处是同种数据类型cout << p(10, 20) << endl;
}using namespace std;int main()
{//test01();test02();system("pause");return 0;
}

3、关系仿函数

(1)功能描述:实现关系对比

(2)仿函数原型

  • template<class T> bool equal_to<T>                 //等于
  • template<class T> bool not_equal_to<T>          //不等于
  • template<class T> bool greater<T>                   //大于
  • template<class T> bool greater_equal<T>        //大于等于
  • template<class T> bool less<T>                        //小于
  • template<class T> bool less_equal<T>            //小于等于

(3)示例:大于的使用

#include<iostream>
#include<functional>
#include<vector>
using namespace std;
#include<algorithm>
#include<functional>//内建的函数对象  _关系仿函数class myCompare 
{
public:bool operator()(int v1,int v2){return v1 > v2;}
};void test01()
{vector<int> v;v.push_back(10);v.push_back(30);v.push_back(40);v.push_back(20);v.push_back(50);for (vector<int>::iterator it = v.begin(); it != v.end(); it++){cout << *it << "  ";}cout << endl;//降序排序sort(v.begin(), v.end(),myCompare());cout << "-------------------------";cout << "降序排序" << endl;for (vector<int>::iterator it = v.begin(); it != v.end(); it++){cout << *it << "  ";}cout << endl;
}void test02()
{vector<int> v;v.push_back(10);v.push_back(30);v.push_back(40);v.push_back(20);v.push_back(50);for (vector<int>::iterator it = v.begin(); it != v.end(); it++){cout << *it << "  ";}cout << endl;//降序排序sort(v.begin(), v.end(), greater<int>());cout << "-------------------------";cout << "使用内建函数对象  降序排序" << endl;for (vector<int>::iterator it = v.begin(); it != v.end(); it++){cout << *it << "  ";}cout << endl;
}int main()
{//test01();test02();system("pause");return 0;
}

 注意:sort函数的源码中可以看到,默认排序用的less<>,也就是小于(v1<v2),所以默认排序时升序哦!

4、逻辑仿函数

(1)功能描述:实现逻辑运算

(2)仿函数原型:

  • template<class T> bool logical_and<T>                  //逻辑与
  • template<class T> bool logical_or<T>                     //逻辑或
  • template<class T> bool logical_not<T>                   //逻辑非

(3)示例:逻辑非的使用

#include<iostream>
#include<functional>
#include<algorithm>
#include<vector>
using namespace std;//内建函数对象  logical_notvoid test01()
{vector<bool>v;v.push_back(true);v.push_back(false);v.push_back(true);v.push_back(false);for (vector<bool>::iterator it = v.begin(); it != v.end(); it++){cout << *it << "  ";}cout << endl;//利用逻辑非  将容器v  搬运到  容器v2中,并执行取反操作vector<bool>v2;v2.resize(v.size());transform(v.begin(), v.end(), v2.begin(), logical_not<bool>());for (vector<bool>::iterator it = v2.begin(); it != v2.end(); it++){cout << *it << "  ";}cout << endl;}int main()
{test01();system("pause");return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/586214.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

WPF+Halcon 培训项目实战(11):HS组件封装

文章目录 前言相关链接项目专栏运行环境匹配图片封装组件新增类库项目选择依赖顺序并添加Nuget修改原本矩形方法运行结果&#xff1a; 对矩形进行抽象封装抽象基类矩形抽象改造 圆形抽象封装代码运行结果 前言 为了更好地去学习WPFHalcon&#xff0c;我决定去报个班学一下。原…

Baumer工业相机堡盟工业相机如何通过NEOAPI SDK设置相机的固定帧率(C++)

Baumer工业相机堡盟工业相机如何通过NEOAPI SDK设置相机的固定帧率&#xff08;C&#xff09; Baumer工业相机Baumer工业相机的固定帧率功能的技术背景CameraExplorer如何查看相机固定帧率功能在NEOAPI SDK里通过函数设置相机固定帧率 Baumer工业相机通过NEOAPI SDK设置相机固定…

harmonyOS Column组件通过space属性设置内部元素间距

例如 我们代码如下 import router from ohos.router Entry Component struct Index {build() {Row() {Column() {Text("年后")Text("一起")Text("旅游")}.width(100%)}.height(100%)} }运行之后 元素都粘连到一起 显然不太好看 我们就可以通过…

PM大逃亡

欢迎来到程序小院 PM大逃亡 玩法&#xff1a;点击白色的小鬼&#xff0c;滑动鼠标移动&#xff0c;不要碰到黑色的怪物&#xff0c; 怪物会越来越多&#xff0c;看看你能坚持多久&#xff0c;快去大逃亡吧^^。开始游戏https://www.ormcc.com/play/gameStart/233 html <div…

分享Python采集40个NET整站程序源码,总有一款适合您

分享Python采集40个NET整站程序源码&#xff0c;总有一款适合您 Python采集的40个NET整站程序源码下载链接&#xff1a;https://pan.baidu.com/s/1z54JHJkFYa4Kx2oBtPrn_w?pwd2ta4 提取码&#xff1a;2ta4 商品评论网站系统 小孔子内容管理系统XkCms V2.0 友间别墅整站程…

【win10】解决重装系统后笔记本无法调节亮度的问题

问题描述 笔记本重装系统后发现之前的fn快捷键调节亮度的功能無了&#xff0c;检查过后发现n卡控制面板&#xff0c;电源选项这些能调节屏幕亮度的地方一个都不行。笔记本一直是最强亮度非常伤眼睛。 问题分析 重装系统后发生这种情况大概率是因为之前的显卡驱动没了&#…

【rar转zip】如何将rar文件轻松转换成zip

今天和大家分享三个rar压缩包改成zip格式的方法&#xff0c;希望能够帮助到大家&#xff01; 方法一&#xff1a; 直接修改rar压缩包的后缀名变为zip&#xff0c;就可以修改压缩包文件格式了 方法二&#xff1a; 先将rar压缩包解压出来&#xff0c;然后再将解压出的文件进行…

【MATLAB】BiGRU神经网络时序预测算法

有意向获取代码&#xff0c;请转文末观看代码获取方式~也可转原文链接获取~ 1 基本定义 BiGRU神经网络时序预测算法是一种基于双向门控循环单元&#xff08;GRU&#xff09;的多变量时间序列预测方法。该方法结合了双向模型和门控机制&#xff0c;旨在有效地捕捉时间序列数据中…

git 常用操作合集

✨专栏介绍 在当今数字化时代&#xff0c;Web应用程序已经成为了人们生活和工作中不可或缺的一部分。而要构建出令人印象深刻且功能强大的Web应用程序&#xff0c;就需要掌握一系列前端技术。前端技术涵盖了HTML、CSS和JavaScript等核心技术&#xff0c;以及各种框架、库和工具…

CCSK认证:开启云安全领域的黄金大门

&#x1f31f;你是否对云安全领域充满热情&#xff1f;是否希望提升自己在云安全领域的专业性和竞争力&#xff1f;CCSK认证是你的不二之选&#xff01; &#x1f525;CCSK简介&#xff1a; CCSK是国际云安全联盟&#xff08;Cloud Security Alliance&#xff0c;CSA&#xff…

【前端基础】——原型与原型链详解,看一篇即可【图文版】

前言 本文旨在通过图文的方式&#xff0c;一步步回顾原型链的整个流程是如何运作的&#xff0c;如果你刚好在电脑旁边&#xff0c;不妨跟着我的思路&#xff0c;一起走一遍敲一遍代码流程&#xff0c;你会发现原型链并没有你想的那么复杂。 new关键字 我们先看这一个代码&am…

RIS 系列 See-Through-Text Grouping for Referring Image Segmentation 论文阅读笔记

RIS 系列 See-Through-Text Grouping for Referring Image Segmentation 论文阅读笔记 一、Abstract二、引言三、相关工作3.1 Semantic Segmentation and Embeddings3.2 Referring Expression Comprehension3.3 Referring Image Segmentation 四、方法4.1 视觉表示4.2 文本表示…

【yolofastest上手】

一、前言 yolofastest网上资料比较少&#xff0c;也没有视频教学&#xff0c;所以想要使用参考了很多资料&#xff0c;只能说各资料都不尽全&#xff0c;让刚接触的小白无从下手。 参考资料: github地址 yolo-fastest 快速上手 修改参数遇到的问题 能在ARM-CPU上实时识别图像的…

销售转行上位机编程:我的学习与职业经历分享

同学们好&#xff0c;我是杨工&#xff0c;原先是一名销售。 通过在华山编程培训中心学习&#xff0c;成功转行上位机编程&#xff0c;对此我想分享学习和职业经历。 在职业生涯的早期&#xff0c;我并没有考虑将技术融入到我的工作中。然而&#xff0c;在几次创业的失败后&a…

{MySQL}索引事务和JDBC

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、索引1.1索引是什么1.2作用1.3代码 二、事务2.1什么是事务2.2使用 三.JDBC总结 前言 接着上次&#xff0c;继续讲下MySQL 提示&#xff1a;以下是本篇文章正…

Jmeter吞吐量控制器总结

吞吐量控制器(Throughput Controller) 场景&#xff1a; 在同一个线程组里, 有10个并发, 7个做A业务, 3个做B业务,要模拟这种场景,可以通过吞吐量模拟器来实现。 添加吞吐量控制器 用法1: Percent Executions 在一个线程组内分别建立两个吞吐量控制器, 分别放业务A和业务B …

用CSS中的动画效果做一个转动的表

<!DOCTYPE html> <html lang"en"><head><meta charset"utf-8"><title></title><style>*{margin:0;padding:0;} /*制作表的样式*/.clock{width: 500px;height: 500px;margin:0 auto;margin-top:100px;border-rad…

【数据结构】双向带头循环链表的实现

前言&#xff1a;在前面我们学习了顺序表、单向链表&#xff0c;今天我们在单链表的基础上进一步来模拟实现一个带头双向链表。 &#x1f496; 博主CSDN主页:卫卫卫的个人主页 &#x1f49e; &#x1f449; 专栏分类:数据结构 &#x1f448; &#x1f4af;代码仓库:卫卫周大胖的…

USB -- STM32F103复合设备(HID+MassStorage)传输讲解(十)

目录 链接快速定位 前沿 1 描述符讲解 1.1 设备描述符 1.2 配置描述符 1.3 接口描述符 1.4 功能描述符 1.5 端点描述符 1.6 字符串描述符 1.7 报告描述符 2 运行演示 链接快速定位 USB -- 初识USB协议&#xff08;一&#xff09; 源码下载请参考链接&#xff1a;…

java中PhantomReference WeakReference SoftReference垃圾回收触发时机以及使用场景

java 中对象引用一般引用分为四种情况 强引用 即我们平常创建的对象 Object obj new Object() 垃圾回收触发时机 在没设置 jvm 参数 -XX:PretenureSizeThreshold 和 -XX:MaxTenuringThreshold 的情况下 -XX:PretenureSizeThreshold 的值为 0&#xff0c;即未设置大对象直接…