用于多种结构体的函数对象

原创 2012年03月31日 11:47:41
template<class T, class ValueType>
struct Cmp
{
    ValueType T::*member_;
    enum emMemberType {emInt, emStr, emSz, emIP} membertype_;
    enum emOrderType {emAsc, emDesc} ordertype_;
    
    Cmp(ValueType T::*m, emMemberType mt, emOrderType ot) 
        : member_(m), membertype_(mt), ordertype_(ot){}
    
    bool operator () (T const& t1, T const& t2)
    {
        if (membertype_ == emInt)
        {// 整数
            if (ordertype_ == emAsc)
                return (t1.*member_) < (t2.*member_);
            else if (ordertype_ == emDesc)
                return (t1.*member_) > (t2.*member_);                
        }
        else if (membertype_ == emStr)
        {// CString
            if (ordertype_ == emAsc)
                return StrCmpI(LPCTSTR((t1.*member_)), LPCTSTR((t2.*member_))) < 0;
            else if (ordertype_ == emDesc)
                return StrCmpI(LPCTSTR((t1.*member_)), LPCTSTR((t2.*member_))) > 0;
          //  如果ValueType是int类型,因为编译的时候不能判断memebertype_的值,所以此处仍旧会
          // 实例化" return StrCmpI(LPCTSTR((t1.*member_)), LPCTSTR((t2.*member_))) > 0;“函数,此处是依靠LPCTSTR将int*强转为const char*,所以
          // 编译不会有问题,但如果用" return StrCmpI(t1.*member_, (t2.*member_) > 0;“就编译错误了,这等于给StrCmpI传递了一个int*的参数
         }
        else if (membertype_ == emSz)
        {// 字符数组
            if (ordertype_ == emAsc)
                return StrCmpI(LPCTSTR(&(t1.*member_)), LPCTSTR(&(t2.*member_))) < 0;
            else if (ordertype_ == emDesc)
                return StrCmpI(LPCTSTR(&(t1.*member_)), LPCTSTR(&(t2.*member_))) > 0;
        }
        else if (membertype_ == emIP)
        {// IP
            if (ordertype_ == emAsc)
                return (int)htonl(inet_addr(LPCSTR(&(t1.*member_)))) < (int)htonl(inet_addr(LPCSTR(&(t2.*member_))));
            else if (ordertype_ == emDesc)
                return (int)htonl(inet_addr(LPCSTR(&(t1.*member_)))) > (int)htonl(inet_addr(LPCSTR(&(t2.*member_))));
        }
        return true;
    }
};


用法举例:

struct stru1
{
	int a;
	CString b;
	TCHAR szE[10];
};

vector<stru1> v1;

sort(v1.begin(), v1.end(), Cmp<stru1, int>(&stru1::a, Cmp<stru1, int>::emInt, Cmp<stru1, int>::emDesc));
sort(v1.begin(), v1.end(), Cmp<stru1, TCHAR[10]>(&stru1::szE, Cmp<stru1, TCHAR[10]>::emSz, Cmp<stru1, TCHAR[10]>::emDesc));
sort(v1.begin(), v1.end(), Cmp<stru1, CString>(&stru1::b, Cmp<stru1, CString>::emStr, Cmp<stru1, CString>::emDesc));



版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

C语言里用结构体和指针函数实现面向对象思想

一、基础研究 观察如下两个程序a.c和b.c: A.c:   B.c:     这两个程序都是要实现在屏幕上第10行40列打印一个绿色的字符c:   ...

C++小课堂--第一期---面向对象之前 --- 实现函数返回结构体,实现大数据的传输

即将开启C++学习之旅,是时候该说些什么了; 好了话不多说,上代码: #include using namespace std; struct course{ double math; ...

JNI调用c++函数,该函数的参数是结构体(——对象的传递)

第三方C++函数接口为 int api_get_logfile(Struct fileinfo tfile),参数是个结构体,且套了另一个结构体: struct fileinfo{  char...

C/C++日常学习总结(第二篇)结构体和类的大小及区别&为什么是new一个对象而不是malloc

1.大家在定义一个动态

cdev结构体和相关函数

  • 2015年08月26日 17:57
  • 47KB
  • 下载

QT: QByteArray储存二进制数据(包括结构体,自定义QT对象)

因为利用QByteArray可以很方便的利用其API对内存数据进行访问和修改, 构建数据库blob字段时必不可少; 那如何向blob内写入自定义的结构体和类 1. 利用memcpy拷贝内存数据 ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:用于多种结构体的函数对象
举报原因:
原因补充:

(最多只允许输入30个字)