在类中,我试图通过传递相同类的方法来排序向量。但它在编译时会出错。任何人都可以告诉问题是什么?谢谢!传递类方法而不是std :: sort中的函数
它提供了以下错误: 参数bool (Sorter::)(D&, D&)' does not match
bool类型(分拣机:: *)(d &,d &)”
我一直在使用sortBynumber(D const& d1, D const& d2)
#include<vector>
#include<stdio.h>
#include<iostream>
#include<algorithm>
class D {
public:
int getNumber();
D(int val);
~D(){};
private:
int num;
};
D::D(int val){
num = val;
};
int D::getNumber(){
return num;
};
class Sorter {
public:
void doSorting();
bool sortByNumber(D& d1, D& d2);
std::vector<D> vec_D;
Sorter();
~Sorter(){};
private:
int num;
};
Sorter::Sorter(){
int i;
for (i = 0; i < 10; i++){
vec_D.push_back(D(i));
}
};
bool Sorter::sortByNumber(D& d1, D& d2){
return d1.getNumber() < d2.getNumber();
};
void Sorter::doSorting(){
std::sort(vec_D.begin(), vec_D.end(), this->sortByNumber);
};
int main(){
Sorter s;
s.doSorting();
std::cout << "\nPress RETURN to continue...";
std::cin.get();
return 0;
}
你为什么要'sortByNumber'作为成员函数?它也可以是一个免费的功能。 – Naveen 2010-05-11 05:16:01
你不必明确说明'D'的析构函数。编译器可以免费获得完全相同的代码。更少的代码,更少的错误。 ;)另外,我看到'Sorter :: vector'是公开的。只是一个观察;这可能不是你想要的。另一件事:如果你知道向量的大小,那么你可以在'Sorter'的初始化列表中指定它,以避免重新分配。其他人已经谈到了const-correctness的重要性,所以你应该注意这一点。最后一件事情是:在for循环中,你应该有'i'作为循环的局部变量。 – wilhelmtell 2010-05-11 06:02:07