Function Object & Function Object Adapters

本文详细介绍了C++标准程序库中的Function Object及其适配器的使用方法。Function Object可以提高函数调用效率,通过将函数调用转换为内联调用。此外,文章还展示了如何使用Function Object Adapters绑定参数,简化比较操作。
标准的程序库中,事先定义了一组 function object,  function object 实现了本来可以以独立函数加以定义的事物, 这样做主要是为了效率, 因为他将call变成了inline.

原来的函数是:
bool less_than(int v1, int v2)
{
 return v1<v2 ? true:false;
}

vector<int>::iterator i = sort(v.begin(), v.end(), less_than);

用function object替换后为
vector<int>::iterator i = sort(v.begin(), v.end(), less<int>() );

这两段程序都是同样的功能, 升序排列.

而Function Object Adapters 则是将比较关系中的1ST,2ND参数绑定到用户指定的类型上面去,从而使参数从 一个二元参数转变成为一个一元参数

通过使用bind1st, bind2nd 方法分别可以绑定第一个或第二个参数.
如下程序:
#include<functional>
vector<int> filter( const vector<int> &vec,
 int val, less<int>& it)
{
 vector<int> nvec;
 vector<int>::const_iterator iter = vec.begin();
 
 while (( iter = find_if( iter, vec.end(), bind2nd(it, val))) != vec.end() )
 {
 nvec.push_back(*iter);
 iter++;
 }
 return nvect;

/*! * chartjs-adapter-luxon v1.2.0 * https://www.chartjs.org * (c) 2022 chartjs-adapter-luxon Contributors * Released under the MIT license */ !function(e,t){&quot;object&quot;==typeof exports&amp;&amp;&quot;undefined&quot;!=typeof module?t(require(&quot;chart.js&quot;),require(&quot;luxon&quot;)):&quot;function&quot;==typeof define&amp;&amp;define.amd?define([&quot;chart.js&quot;,&quot;luxon&quot;],t):t((e=&quot;undefined&quot;!=typeof globalThis?globalThis:e||self).Chart,e.luxon)}(this,(function(e,t){&quot;use strict&quot;;const n={datetime:t.DateTime.DATETIME_MED_WITH_SECONDS,millisecond:&quot;h:mm:ss.SSS a&quot;,second:t.DateTime.TIME_WITH_SECONDS,minute:t.DateTime.TIME_SIMPLE,hour:{hour:&quot;numeric&quot;},day:{day:&quot;numeric&quot;,month:&quot;short&quot;},week:&quot;DD&quot;,month:{month:&quot;short&quot;,year:&quot;numeric&quot;},quarter:&quot;&#39;Q&#39;q - yyyy&quot;,year:{year:&quot;numeric&quot;}};e._adapters._date.override({_id:&quot;luxon&quot;,_create:function(e){return t.DateTime.fromMillis(e,this.options)},init(e){this.options.locale||(this.options.locale=e.locale)},formats:function(){return n},parse:function(e,n){const i=this.options,r=typeof e;return null===e||&quot;undefined&quot;===r?null:(&quot;number&quot;===r?e=this._create(e):&quot;string&quot;===r?e=&quot;string&quot;==typeof n?t.DateTime.fromFormat(e,n,i):t.DateTime.fromISO(e,i):e instanceof Date?e=t.DateTime.fromJSDate(e,i):&quot;object&quot;!==r||e instanceof t.DateTime||(e=t.DateTime.fromObject(e,i)),e.isValid?e.valueOf():null)},format:function(e,t){const n=this._create(e);return&quot;string&quot;==typeof t?n.toFormat(t):n.toLocaleString(t)},add:function(e,t,n){const i={};return i[n]=t,this._create(e).plus(i).valueOf()},diff:function(e,t,n){return this._create(e).diff(this._create(t)).as(n).valueOf()},startOf:function(e,t,n){if(&quot;isoWeek&quot;===t){n=Math.trunc(Math.min(Math.max(0,n),6));const t=this._create(e);return t.minus({days:(t.weekday-n+7)%7}).startOf(&quot;day&quot;).valueOf()}return t?this._create(e).startOf(t).valueOf():e},endOf:function(e,t){return this._create(e).endOf(t).valueOf()}})}));
12-26
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值