依据类的成员来对类进行排序的泛型方法 (转)

依据类的成员来对类进行排序的泛型方法 (转)[@more@]

//最近在工作中,遇到这样一个问题:
//一个类中有十几个成员数据,我需要根据不同的成员提供不同的排序方法. 如下:

class Cell
{
public:
  string name;
  string time;
  int  tchDrop;
  double traffic;
  // more …
};

//最近正在学习STL,所以我想结合所学的知识,设计出一种通用的方法,只要提
//供类的成员指针和排序准则(即函数对象),就可
//以同STL算法搭配,对类成员进行比较排序,比较等.

template >
class Comp_Mem_Data
  :public binary_function
{
public:
 Comp_Mem_Data( T (C::*pmd) , Pred pred=Pred() )
  //Pred类采用默认构造函数,并不一定都适用。要注意。 
 :m_pmd(pmd),m_pred(pred)
 {};

 //比较 两个类对象 的成员
 bool operator() (const C& a , const C& b) const
 {
 return m_pred( a.*m_pmd , b.*m_pmd );
 };

private:
 T  (C::*m_pmd); //类成员指针
 Pred m_pred;  //比较函数
};

//仿照标准库中的 bind1st,bind2nd 的做法,提供一个方便的调用形式
template
Comp_Mem_Data >  comper_mem_data( T (C::*pmd) )
{
 return Comp_Mem_Data >(pmd,less() );
}
template
Comp_Mem_Data  comper_mem_data( T (C::*pmd) ,Pred pred )
{
 return Comp_Mem_Data(pmd,pred);
}

//以下就可以开始比较了.
// sort(vCell.begin(),vCell.end(), comper_mem_data( &Cell::name) );
//sort(vCell.begin(),vCell.end(), comper_mem_data( &Cell::traffic , greater() );
//等等

//以下是测试程序 在BCB5.5 、 MSVC6.0 中测试通过

#include
#include
#include
#include
#include
#include
#include
#include
using namespace std;

inline ostream& operator << (ostream& out,const Cell& cell)
{
 out< < < < // more …
 < return out;
}

template
void output(Container cont) 
{
 cout< for(int j=0;j cout<}

int main()
{
 vector vCell;
 Cell  cl;
 srand( (unsigned)time( NULL ) );
 for(int i=0;i<10; ++i)
 {
 cl.name=static_cast(i+'A');
 cl.time=static_cast(rand()%10+'1');
 cl.tchDrop=rand()%100;
 cl.traffic=rand()*100.0/RAND_MAX;
 vCell.push_back(cl);
 }

 sort(vCell.begin(),vCell.end(), comper_mem_data(&Cell::tchDrop) );
 output(vCell);
 sort(vCell.begin(),vCell.end(), comper_mem_data(&Cell::traffic, greater() ) );
 output(vCell);

 vector::const_iterator iter=find_if( vCell.begin() , vCell.end() ,
   bind2nd(comper_mem_data(&Cell::name , equal_to() ),cl )
 );
 cout<

 char lc;
 cin>>lc;
 return 0;
}

//程序的一个输出如下:
/*
cell name | time | tchDrop | traffic
A | 3 | 2 | 47.0168 |
C | 1 | 2 | 66.5151 |
D | 5 | 19 | 86.5017 |
F | 9 | 23 | 11.1087 |
E | 5 | 78 | 75.7897 |
G | 7 | 84 | 54.2253 |
H | 7 | 88 | 61.1774 |
I | 1 | 90 | 59.2578 |
J | 3 | 94 | 89.9625 |
B | 6 | 99 | 89.2514 |
cell name | time | tchDrop | traffic
J | 3 | 94 | 89.9625 |
B | 6 | 99 | 89.2514 |
D | 5 | 19 | 86.5017 |
E | 5 | 78 | 75.7897 |
C | 1 | 2 | 66.5151 |
H | 7 | 88 | 61.1774 |
I | 1 | 90 | 59.2578 |
G | 7 | 84 | 54.2253 |
A | 3 | 2 | 47.0168 |
F | 9 | 23 | 11.1087 |
cl is find
//*/

//用同样的方法,还可以制作出比较两个类成员函数返回值的泛型类,
// 类数据成员 与 同类型的常数参数相比较的泛型类来。
//此处不一一列出。

//以上不当之处,还请各位大虾不吝指教。


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/10752043/viewspace-960702/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/10752043/viewspace-960702/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值