打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
函数对象

算术函数对象

预定义的算术函数对象支持加减乘除求余和取反调用的操作符是与Type 
关联的实例对一个class 类型如果它提供了该操作符的重载实例则调用该实例
加法plus<Types>
plus<string> stringAdd;
// 调用 string::operator+()
sres = stringAdd( sval1, sval2 );
dres = BinaryFunc( plus<double>(), dval1, dval2 );
减法minus<Type>
minus<int> intSub;
ires = intSub( ival1, ival2 );
dres = BinaryFunc( minus<double>(), dval1, dval2 );
乘法multiplies<Type>
multiplies<complex> complexMultiplies;
cres = complexMultiplies( cval1, cval2 );
dres = BinaryFunc( multiplies<double>(), dval1, dval2 );
除法divides<Type>
divides<int> intDivides;
ires = intDivides( ival1, ival2 );
dres = BinaryFunc( divides<double>(), dval1, dval2 );
求余modulus<Type>
modulus<int> IntModulus;
Ires = IntModulus( Ival1, Ival2 );
ires = BinaryFunc( modulus<int>(), ival2, ival1 );
取反negate<Type>
negate<int> intNegate;
ires = intNegate( ires );
Ires = UnaryFunc( negate<int>(), Ival1 );
 

关系函数对象

预定义的关系函数对象支持等于不等于大于大于等于小于和小于等于
等于equal_to<Type>
equal_to<string> stringEqual;
sres = stringEqual( sval1, sval2 );
ires = count_if( svec.begin(), svec.end(),
equal_to<string>(), sval1 );
不等于not_equal_to<Type>
not_equal_to<complex> complexNotEqual;
cres = complexNotEqual( cval1, cval2 );
ires = count_if( svec.begin(), svec.end(),
not_equal_to<string>(), sval1 );
大于greater<Type>
greater<int> intGreater;
ires = intGreater( ival1, ival2 );
ires = count_if( svec.begin(), svec.end(),
greater<string>(), sval1 );
大于等于greater_equal<Type>
greater_equal<double> doubleGreaterEqual;
dres = doubleGreaterEqual( dval1, dval2 );
ires = count_if( svec.begin(), svec.end(),
greater_equal<string>(), sval1 );
小于less<Type>
less<int> IntLess;
Ires = IntLess( Ival1, Ival2 );
ires = count_if( svec.begin(), svec.end(),
less<string>(), sval1 );
小于等于less_equal<Type>
less_equal<int> intLessEqual;
ires = intLessEqual( ival1, ival2 );
ires = count_if( svec.begin(), svec.end(),
less_equal<string>(), sval1 );
 

逻辑函数对象

预定义的逻辑函数对象支持逻辑与两个操作数都为true 时结果值为true——应用与
Type 相关联的&& 逻辑或两个操作数中有一个为true 返回true——应用与Type 相关联
|| 和逻辑非操作数为false 则返回true——应用与Type 相关联的!操作符
逻辑与logical_and<Type>
logical_and<int> intAnd;
ires = intAnd( ival1, ival2 );
dres = BinaryFunc( logical_and<double>(), dval1, dval2 );
逻辑或logical_or<Type>
logical_or<int> intSub;
ires = intSub( ival1, ival2 );
dres = BinaryFunc( logical_or<double>(), dval1, dval2 );
逻辑非 logical_not<Type>
logical_not<int> IntNot;
Ires = IntNot( Ival1, Ival2 );
dres = UnaryFunc( logical_not<double>(), dval1 );
 

函数对象的函数适配器

标准库还提供了一组函数适配器用来特殊化或者扩展一元和二元函数对象适配器是
一种特殊的类它被分成下面两类:
绑定器binder ( binder ) 通过把二元函数对象的一个实参绑定到一个特殊的值上
将其转换成一元函数对象例如为了计数一个容器中小于或等于10 的元素的个数我们可能会向count_if()传递一个less_equal 函数对象以及一个被绑定为10 的实参。
取反器negator ( negator ) 是一个将函数对象的值翻转的函数适配器例如为了
计数一个容器中所有大于10 的元素的个数我们可以向count_if()传递less_equal 函数对象的
negator 该函数对象有一个实参被绑定为10 当然在这种情况下直接传递greater 对象
binder 并把一个实参绑定为10 更为简洁明了。
C++标准库提供了两种预定义的binder 适配器bind1st 和bind2nd 正如你所预料的
bind1st 把值绑定到二元函数对象的第一个实参上bind2nd 把值绑定在第二个实参上例如
为了计数容器中所有小于或等于10 的元素的个数我们可以这样向count_if()传递
count_if( vec.begin(), vec.end(),
bind2nd( less_equal<int>(), 10 ));
标准库提供了两个预定义的negator 适配器not1 和not2 同样正如你所料想的not1
翻转一元预定义函数对象的真值而not2 翻转二元谓词函数的真值为了取反less_equal 函
数对象的绑定我们可以这样写
count_if( vec.begin(), vec.end(),
not1( bind2nd( less_equal<int>(), 10 )));

实现函数对象

函数对象类定义的最简单形式包含一个被重载的函数调用操作符例如下面是一个二
元函数对象它判定一个值是否小于等于10
// 函数对象类的简单形式
class less_equal_ten {
public:
bool operator() ( int val )
{ return val <= 10; }
};
使用这个对象的方式与使用预定义函数对象的方式相同例如下面是修改后的count_if()
调用它使用了我们的函数对象
count_if( vec.begin(), vec.end(), less_equal_ten() );
毫无疑问这个类是相当局限的我们可以应用一个negator 来计数容器中大于10 的元
素的个数
count_if( vec.begin(), vec.end(),
not1(less_equal_ten()) );
我们也可以通过允许用户提供一个与每个元素比较的值来扩展我们的实现一种做法是
引入一个数据成员来存储被比较的值以及一个构造函数把这个成员初始化为用户指定的值
class less_equal_value {
public:
less_equal_value( int val ) : _val( val ) {}
bool operator() ( int val ) { return val <= _val; }
private:
int _val;
};
我们现在用这个对象指定一个任意的整数值例如下面的调用计数小于等于25 的元素
的个数
count_if( vec.begin(), vec.end(), less_equal_value( 25 ));
另外一种类的实现方式不使用构造函数它根据被比较的值对类参数化例如
template < int _val >
class less_equal_value {
public:
bool operator() ( int val ) { return val <= _val; }
};
下面给出了怎样调用这个类来计数小于等于25 的元素的个数
count_if( vec.begin(), vec.end(), less_equal_value<25>() );

转自:http://hqlong.bokee.com/viewdiary.15254726.html
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
引用
C++ const引用详解
指针
STL运用的C++技术(6)——函数对象
C++ Primer第四章表达式习题
const 用法总结(C++)
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服