我在使用std::stable_sort
时遇到类型问题
我一直收到错误:
argument of type 'bool (Memory::)(const Mem&, const Mem&)' does not match 'bool (Memory::*)(const Mem&, const Mem&)'
我不明白为什么它会显示为指针。。。如果有人能看一眼,我将不胜感激。
Memory.cpp:
#include <vector>
#include <algorithm>
#include <iostream>
#include <set>
#include "Memory.h"
#include "constants.hpp"
Memory::Memory(int _type) {
fit_type = _type;
blocks = 1;
mem[0].address = 0;
mem[0].size = 2048;
mem[0].item_id = EMPTY;
}
void Memory::sort_mem_list() {
// Sort by address
std::stable_sort(mem.begin(), mem.end(), Memory::compareByAddress );
}
bool Memory::compareByAddress(const Mem &a, const Mem &b) {
return a.address < b.address;
}
和内存.hpp
#ifndef MEMORY_H_
#define MEMORY_H_
#include <vector>
#include "process.h"
#include "constants.hpp"
class Memory {
public:
Memory(int);
int add_item(Process pr);
void remove_item();
void sort_mem_list();
void set_fit_type(int);
void memory_dump();
private:
bool compareBestFit(const Mem & a, const Mem & b);
bool compareWorstFit(const Mem & a, const Mem & b);
bool compareByAddress(const Mem & a, const Mem & b);
bool compareByProcess(const Mem & a, const Mem & b);
int fit_type;
int memory_size;
int blocks;
std::vector<Mem> mem;
};
#endif /* MEMORY_H_ */
Mem(目前为常量.hpp)
struct Mem {
int address;
int size;
int item_id;
Mem() {
address = 0;
size = 0;
item_id = EMPTY;
}
Mem(int a, int b, int c) {
address = a;
size = b;
item_id = c;
}
};
我相信这是一件相当简单的事情,我只是以某种方式把申报搞砸了,但我已经坚持了一段时间,所以第二双眼睛会很有帮助。
如果您计划使用一个成员函数作为传递给std::stable_sort()
的比较器,那么它需要是一个static
函数。