对向量<常量字符 *> 进行排序

Sorting a vector<const char *>

本文关键字:gt 排序 常量 向量 lt 字符      更新时间:2023-10-16
for ( fs::directory_iterator dir_itr2( out_folder ); dir_itr2 != end_iter; ++dir_itr2 )
{
cout << "Path del file da inserire nel vettore:" << dir_itr2->path().string().c_str() << endl;
final_path.push_back(dir_itr2->path().string().c_str());

}
sort( final_path.begin(), final_path.end() );
cout << "Vettore di path da aprire in ordine" << endl;
for(vector<const char *>::iterator fp_itr2=final_path.begin(); fp_itr2!=final_path.end(); ++fp_itr2)
{       
cout << "Path: " << *fp_itr2 << endl;
}

在这里,我试图将我的路径放在向量中,因为我需要有序列表,但 cout 的输出是这样的:

Path del file da inserire nel vettore:/srv/FD/super_tracker/tracks/180426163618363.txt
Path del file da inserire nel vettore:/srv/FD/super_tracker/tracks/180426163654027.txt
Path del file da inserire nel vettore:/srv/FD/super_tracker/tracks/180530150135770.txt
Path del file da inserire nel vettore:/srv/FD/super_tracker/tracks/180426163414599.txt
Path del file da inserire nel vettore:/srv/FD/super_tracker/tracks/180530150235481.txt
Path del file da inserire nel vettore:/srv/FD/super_tracker/tracks/180530150132796.txt
Path: 
Path: 
Path: 
Path: 
Path: 
Path:

提前谢谢。

正如评论所说,不要使用char*.其次,应使用调试器。

sort()失败的原因是,您根据指针在内存中指向的位置对指针进行排序,而不是使用指向的字符。

您可以使用谓词来告诉sort()如何对对象进行排序:

sort(begin(final_path), end(final_path), 
[](const char* a, const char *b) { return strcmp(a, b) < 0; }
);

但最好的方法肯定是使用string或直接path作为矢量元素的类型。