本文整理汇总了C++中CmdLineParser::at方法的典型用法代码示例。如果您正苦于以下问题:C++ CmdLineParser::at方法的具体用法?C++ CmdLineParser::at怎么用?C++ CmdLineParser::at使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类CmdLineParser
的用法示例。
在下文中一共展示了CmdLineParser::at方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: main
int main(int argc, char *argv[])
{
setlocale(LC_ALL, "Russian");
CmdLineParser parser;
parser << CmdLineItem("path", true, false, false, "Каталог для поиска дубликатов файлов");
int result = parser.parse(argc, argv);
switch(result)
{
case CmdLineParser::Error:
qDebug() << (parser.getLastError() + "\n\n" + parser.getHelpString()).toStdString().c_str();
return 0;
break;
case CmdLineParser::Help:
qDebug() << parser.getHelpString().toStdString().c_str();
return 0;
break;
}
QElapsedTimer timer;
timer.start();
QString path = parser.at("path")->getValue().at(0);
qDebug() << "Указанный каталог: " << path;
QStringList files = Files::countDir(path, QStringList());
qDebug() << "Найдено файлов: " << files.size();
qDebug() << "Timer:" << timer.elapsed();
QVector<MyFileInfo> fileInfoList;
for(int i = 0 ; i < files.size(); i++)
{
fileInfoList.append(MyFileInfo(files[i]));
fileInfoList.last().calcSize();
}
qDebug() << "Посчитаны размеры всех файлов";
qDebug() << "Timer:" << timer.elapsed();
qSort(fileInfoList.begin(), fileInfoList.end(), [](const MyFileInfo &_item1, const MyFileInfo &_item2)
{
return _item1.getFileSize() < _item2.getFileSize();
});
qDebug() << "Массив отсортирован по размеру";
qDebug() << "Timer:" << timer.elapsed();
for(int i = 1 ; i < fileInfoList.size(); i++)
{
if(fileInfoList[i].getFileSize() == fileInfoList[i - 1].getFileSize())
{
if(!fileInfoList[i].isHashPresent()) fileInfoList[i].calcHash();
if(!fileInfoList[i - 1].isHashPresent()) fileInfoList[i - 1].calcHash();
if(fileInfoList[i].getHash() == fileInfoList[i - 1].getHash())
{
if(fileInfoList[i].compareFiles(fileInfoList[i - 1]))
{
qDebug() << fileInfoList[i].toString();
qDebug() << fileInfoList[i - 1].toString();
qDebug() << "------------------------\n";
}
}
}
}
qDebug() << "Timer:" << timer.elapsed();
qDebug() << "Завершено";
return 0;
}