我正在尝试使用std::sort
包含从boost::filesystem::dictionary_iterator
. 看来,由于排序算法已经进行了n
比较,n
即目录中的文件数量,该信息会丢失,我最终会出现段错误。Valgrind 说我正在使用未初始化的值并进行无效读取。
如何更改我的File
数据类型或算法,以便在两次传递之间保留信息?
#include <iostream>
#include <algorithm>
#include <vector>
#include <string>
#include <boost/filesystem.hpp>
namespace fs = boost::filesystem;
struct File {
fs::path path;
fs::file_status status;
};
bool comp(const File& a, const File& b) {
static size_t count = 0;
std::cout << "Compare function called " << ++count << " times" << std::endl;
std::string a_filename = a.path.filename().native();
std::string b_filename = b.path.filename().native();
return a_filename.compare(b_filename);
}
int main() {
std::vector<File> vec;
// Read directory
fs::directory_iterator it("/etc"), end;
for (; it != end; it++) {
File f = *(new File);
f.path = it->path();
f.status = it->status();
vec.push_back(f);
}
std::sort(vec.begin(), vec.end(), comp);
// Clean up
for (std::vector<File>::iterator it = vec.begin(); it != vec.end(); it++)
delete &(*it);
return 0;
}
(这不是我的实际程序,但表现出相同的行为。)