有效地在C ++中进行命令行参数处理的建议:
注意:仅限Windows专用
1: #include <iostream.h>
2: int main(int argc, char **argv)
而不是,例如:
if ( argc != 3 ) {
....
}
此致
答案 0 :(得分:18)
如果您只想自己处理命令行选项,最简单方式是:
vector<string> args(argv + 1, argv + argc);
位于main()
的顶部。这会将所有命令行参数复制到std::string
s的向量中。然后,您可以使用==
轻松比较字符串,而不是无休止的strcmp()
调用。例如:
int main(int argc, char **argv) {
vector<string> args(argv + 1, argv + argc);
string infname, outfname;
// Loop over command-line args
// (Actually I usually use an ordinary integer loop variable and compare
// args[i] instead of *i -- don't tell anyone! ;)
for (vector<string>::iterator i = args.begin(); i != args.end(); ++i) {
if (*i == "-h" || *i == "--help") {
cout << "Syntax: foomatic -i <infile> -o <outfile>" << endl;
return 0;
} else if (*i == "-i") {
infname = *++i;
} else if (*i == "-o") {
outfname = *++i;
}
}
}
[编辑:我意识到我正在将argv[0]
(程序名称)复制到args
- 已修复。]
答案 1 :(得分:14)
使用C ++,答案通常在Boost ......
答案 2 :(得分:5)
我建议使用图书馆。有经典和尊敬的getopt,我确信其他人。
答案 3 :(得分:5)
有许多好的图书馆可供选择。
Boost Program Options是一个相当重要的解决方案,因为将它添加到您的项目需要您构建提升,并且语法有点令人困惑(在我看来)。但是,它可以执行几乎所有操作,包括使命令行选项覆盖配置文件中设置的那些。
SimpleOpt是一个相当全面但简单的命令行处理器。它是一个单独的文件,具有简单的结构,但只处理将命令行解析为选项,您必须执行所有类型和范围检查。它适用于Windows和Unix,并且还附带了适用于Windows的glob版本。
getopt在Windows上可用。它与Unix机器上的相同,但通常是GPL库。
答案 4 :(得分:2)
这是我最喜欢的命令行管理方式,尤其是当效率问题时。这似乎有点矫枉过正,但我认为这种矫枉过正几乎没有什么缺点。
Use gperf for efficient C/C++ command line processing
缺点:
优点:
使用像eclipse这样的IDE你可以自动执行运行gperf的过程,所以你唯一需要做的就是在配置文件和switch语句中添加一个选项并按下build ...
我使用批处理文件来运行gperf并进行一些清理并使用sed添加包含警戒(在gperf生成的.hpp文件上)...
因此,您的软件中的代码非常简洁和干净,以及一个您不需要手动更改的自动生成的哈希表文件。我怀疑boost :: program_options是否真的会击败即使没有效率优先。
答案 5 :(得分:0)
如果您不想使用boost,我建议this小助手类。
答案 6 :(得分:0)
尝试CLPP库。它是用于命令行参数解析的简单而灵活的库。仅限标题和跨平台。仅使用ISO C ++和Boost C ++库。恕我直言,它比Boost.Program_options更容易。
图书馆:http://sourceforge.net/projects/clp-parser
2010年10月26日 - 新版本2.0rc。修复了许多错误,修改了源代码,文档,示例和注释的完全重构。