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

郑州网站制作服务中超最新积分榜

郑州网站制作服务,中超最新积分榜,网站设计专业的公司,广东科技网站建设类成员函数可以通过函数适配器(function adapters)包装成一个仿函数(重载了operator()的类)&#xff0c;将其搭配于STL算法一起使用。#include <algorithm> #include <functional> #include <vector> #include <iostream>using namespace std;class In…

类成员函数可以通过函数适配器(function adapters)包装成一个仿函数(重载了operator()的类),将其搭配于STL算法一起使用。

#include <algorithm>
#include <functional>
#include <vector>
#include <iostream>using namespace std;class Int
{
public:explicit Int(int i) : m_i(i) {}void print1() const { cout << '[' << m_i << ']'; }void print2(int i) const { cout << '[' << i << ']'; }
private:int m_i;
};int main()
{Int t1(3), t2(7), t3(20), t4(14), t5(68);vector‹Int> Iv;Iv.push_back(t1);Iv.push_back(t2);Iv.push_back(t3);Iv.push_back(t4);Iv.push_back(t5);for_each(Iv.begin(), Iv.end(), mem_fun_ref(&Int::print1));    //okfor_each(Iv.begin(), Iv.end(), mem_fun_ref(&Int::print2));    //err!!}

为何上述代码Int::print1可以搭配for_each使用而Int::print2却不行?我用vs2015编译上述语句出错时跟随所在err可以看到for_each的源代码:

template<class _InIt,class _Fn1> inlinevoid _For_each_unchecked(_InIt _First, _InIt _Last, _Fn1& _Func){    // perform function for each elementfor (; _First != _Last; ++_First)_Func(*_First);}

可知所调用的func的参数是迭代器解引用的对象,该对象类型和这里vector内value_type(元素类型)一样。显然print2的参数是int而不是Int。那么我把print2的参数改为Int是不是就可以了呢?

using namespace std;class Int
{...int get() { return m_i;  }void print2(Int i) const { cout << '[' << i.get() << ']'; }
};...for_each(Iv.begin(), Iv.end(), mem_fun_ref(&Int::print2));    //err!!

结果还是不行,编译报错“ c++ error 2064: term does not evaluate to a function taking 1 arguments”。既然抱怨的是“_Func这个函数不能转为接受一个参数的函数”,但以上代码使用的函数“print2”明明是只接受一个参数的函数,那为什么编译器还会报这个错呢?是因为在这个例子中,mem_fun_ref返回一个仿函数,而这个仿函数接受两个参数,一个是T*指针(也就是方法所在类对象的指针,可理解为this),第二个才是我们需要的Int。所以编译器会产生这个错误。

mem_fun_ref作为一个函数模板,内部返回了一个类模板对象mem_fun_ref_t,大概长这个样子:

template <class S, class T>
inline mem_fun_ref<S, T> mem_fun(S (T::*f)()){ return mem_fun_ref_t<S,T>(f); }template <class S, class T>
class mem_fun_ref_t : public unary_function<T, S> {
public:explicit mem_fun_ref_t(S (T::*pf)()) : f(pf) {}S operator()(T& r) const { return (r.*f)(); }
private:S (T::*f)();
};

mem_fun_ref_t其实是unary_function仿函数的适配器。反正它通过模板参数匹配的手法在mem_fun_ref_t内部推导出了了类的类型T,类成员函数的返回类型S,还存了这个成员函数的指针,一旦调用即operator()通过r.*f进行函数调用。注意f是指针,r.*f表示对f进行解引用(不是*(r.f)噢,这种写法虽然有点奇特)。

回归正题,解决上述这个无法将一个参数以上的成员函数应用于算法的问题,有2种方法:

  1. 将函数print2改为一个静态方法,这样print2就无需this指针就可调用,和一个普通的函数指针无异,因此直接使用&Int::print2即可:

class Int {
public:explicit Int(int i) : m_i(i) {}static void print2(Int obj) { cout << '[' << obj.get() << ']'; }int get() { return m_i;  }
private:int m_i;
};for_each(Iv.begin(), Iv.end(), &Int::print2);
  1. 使用bind,将将接受2个参数的print2绑定为真正接受一个参数Int的函数对象:

class Int {
public:explicit Int(int i) : m_i(i) {}void print2(Int obj) { cout << '[' << obj.get() << ']'; }int get() { return m_i;  }
private:int m_i;
};Int tmp(1);
for_each(Iv.begin(), Iv.end(), std::bind(&Int::print2, tmp, std::placeholders::_1));

以上。

http://www.hkea.cn/news/590493/

相关文章:

  • 做网站4000-262-263网站排名优化软件有哪些
  • 网站双链接怎么做网络舆情监测平台
  • 企业网站建设制作百度网盘下载app
  • asp做一个简单网站网络营销就是seo正确吗
  • 移动wap站点公司网站设计图
  • 网站策划建设seo搜索排名影响因素主要有
  • 大型商业广场网站建设互联网推广方案怎么写
  • p2vr做的网站上传网络广告策划书范文
  • 2022年大连黄页优化搜索引擎营销
  • 宁波有几个区昭通网站seo
  • 建设企业网站方案网站优化软件哪个好
  • 郑州做网站要搜索引擎最新排名
  • wordpress建好站了打不开首页成都关键词优化排名
  • 京东网站开发需求如何做谷歌优化
  • 微信app开发诊断网站seo现状的方法
  • 做旅行网站网站seo优化多少钱
  • 上海专业网站建设咨询网络销售怎么样
  • 奶茶网页设计图片湖南seo网站多少钱
  • 家里电脑做网站服务器如何建立网址
  • 临西做网站哪里便宜seo专业培训课程
  • 高端网站设计报价表个人网上卖货的平台
  • 广州网站优化推广公司网站优化排名资源
  • 济南网站建设大标网络企业seo服务
  • net域名大网站东莞关键词自动排名
  • 做企业平台的网站怎样进行网络营销吸引顾客
  • 天河网站 建设seo信科分公司谷歌搜索引擎网址
  • 西安网站建设招骋外贸如何推广
  • 网站改版降权武汉seo排名公司
  • 南京哪家公司做企业网站 做得比较好百度seo怎么优化
  • 白云做网站SEO市场营销策略有哪些