以下是几种常用的C/C++命令行解析库的对比表格,以及它们的GitHub开源库地址:
库名称 | 语言 | 特点 | 是否支持子命令 | 是否支持配置文件 | 是否支持自动生成帮助信息 | GitHub地址 |
---|---|---|---|---|---|---|
Clara | C++11及以上 | 单一头文件,轻量级,非异常错误处理,自动类型转换 | 是 | 否 | 是 | Clara GitHub |
cxxopts | C++11及以上 | 单一头文件,轻量级,支持多种数据类型,自动帮助信息 | 是 | 否 | 是 | cxxopts GitHub |
CLI11 | C++11及以上 | 功能强大,支持子命令、配置文件,自动生成帮助信息 | 是 | 是 | 是 | CLI11 GitHub |
argparse | C++17 | 现代C++17头文件库,支持多种参数类型,自动帮助信息 | 是 | 否 | 是 | argparse GitHub |
Cmdline | C++ | 轻量级,支持布尔标志和参数绑定,自动生成帮助信息 | 否 | 否 | 是 | Cmdline GitHub |
cargs | C/C++ | 轻量级,支持多种参数类型,自动生成帮助信息 | 否 | 否 | 是 | cargs GitHub |
选择建议:
- 如果你需要轻量级且易于集成的库,可以选择 Clara 或 cxxopts,它们都是单一头文件库,易于集成到项目中。
- 如果你需要功能强大且支持复杂命令行接口,CLI11 是一个不错的选择,它支持子命令、配置文件和自动生成帮助信息。
- 如果你使用的是C语言或需要兼容C语言的库,可以考虑 cargs。
- 如果你需要现代C++17特性支持,argparse 是一个简洁且功能丰富的选择。
以下是几种常用C/C++命令行解析库的简单使用示例
1. Clara
GitHub地址:Clara GitHub
示例代码:
#include <boost/program_options.hpp>
#include <iostream>
namespace po = boost::program_options;
int main(int argc, char* argv[]) {
po::options_description desc("Allowed options");
desc.add_options()
("help,h", "produce help message")
("compression,c", po::bool_switch(), "enable compression");
po::variables_map vm;
po::store(po::parse_command_line(argc, argv, desc), vm);
po::notify(vm);
if (vm.count("help")) {
std::cout << desc << "\n";
return 1;
}
bool compression = vm["compression"].as<bool>();
std::cout << "Compression is "