Portál AbcLinuxu, 13. července 2025 04:26
Jelikož padla spousta návrhů na použití std::sort k řazení, učinil jsem tak. Bohužel však nepociťuji ŽÁDNÉ zrychlení. Připadá mi to úplně stejně rychlé.
void FileInfoList::sort( int column, bool ascending ) { FileInfoComparator fic( column, ascending ); std::sort( begin(), end(), fic ); } bool FileInfoComparator::operator()( const PFileInfo& fi1, const PFileInfo& fi2 ) { if( fi1->isDots() ) return true; if( fi2->isDots() ) return false; if( fi1->isDir() && !fi2->isDir() ) return true; if( fi2->isDir() && !fi1->isDir() ) return false; int cmpRes = 0; off64_t size1,size2; time_t date1, date2; switch( sortColumn ) { case FileInfoList::COLUMN_NAME: cmpRes = g_utf8_collate( fi1->getNameTitle().c_str(), fi2->getNameTitle().c_str() ); break; case FileInfoList::COLUMN_EXT: cmpRes = g_utf8_collate( fi1->getName().c_str(), fi2->getName().c_str() ); break; case FileInfoList::COLUMN_SIZE: fi1->getSize(size1); fi2->getSize(size2); if(size1>size2) cmpRes = 1; else if( size2>size1 ) cmpRes = -1; break; case FileInfoList::COLUMN_DATE: fi1->getDate(date1); fi2->getDate(date2); if(date1>date2) cmpRes = -1; else if(date2>date1) cmpRes = 1; break; case FileInfoList::COLUMN_ATTRS: cmpRes = g_utf8_collate( fi1->getAttrs().c_str(), fi2->getAttrs().c_str() ); break; case FileInfoList::COLUMN_OWNER: cmpRes = g_utf8_collate( fi1->getOwner().c_str(), fi2->getOwner().c_str() ); break; default: cmpRes = g_utf8_collate( fi1->getGroup().c_str(), fi2->getGroup().c_str() ); break; } if(cmpRes == 0) cmpRes = g_utf8_collate( fi1->getName().c_str(), fi2->getName().c_str() ); if(ascending) cmpRes = -cmpRes; return (cmpRes > 0); }
Tiskni
Sdílej:
stat()
nebo lstat()
? Pak by mne nepřekvapilo, pokud by problém byl skutečně tady a ne v samotném řazení seznamu.
typedef shared_ptr<PFileInfo> PFileInfoPtr_t; typedef std::vector<PFileInfoPtr_t> fileContainer;
class FileInfoList: public std::vector<FileInfo*>{ ... }Drží tedy ukazatele. PFileInfo je jen typedef na FileInfo*, abych se vyhnul něčemu jako
const FileInfo*&
v tom operátoru ().
preco neskusit (ako som navrhoval)
- extra komparatory (triedy) pre kazdy typ stlpca
- vyhodit . a .. z filelistu
navyse, nie je doriesena otazka, ako sortovat v pripade rovnosti kriteria (datumy, velkosti, ...)
return cmpRes == 0;vlastne i to moze byt dovod tej "pomalosti"
20:08:39:458 start 20:08:40:419 endsamozrejme, ziskani celeho vypisu rwxrw-rw- by to urcite zpomalilo, ale trideni mi QListView dela uplne sam - krome trideni podle data modifikace. Tam se musi napsat jedna porovnavaci funkce.
bool FileInfoComparator::operator()( const PFileInfo& fi1, const PFileInfo& fi2 )Pokud definice PFileInfo vypada nejak takto
typedef FileInfo* PFileInfo;tak to dohromady nedela to, co nejspis prepodkladate. Vyleze z toho totiz reference na konstatni ukazatel na objekt FileInfo. Neboli primo
fi1
menit nelze, ale objekt, na ktery ukazuje, ano (*fi1 = *fi2
projde). A take je zcela zbytecne cpat na ukazatele jeste reference. IMHO spravna deklarace by mela vypadat takto
bool FileInfoComparator::operator()(const FileInfo* fi1, const FileInfo* fi2 )
ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.