[C++项目框架]gflags和gtest的简单介绍

gflags和gtest的介绍和使用

一 gflags介绍和使用

1.gflags介绍

gflags 是 Google 开发的一个开源库,用于 C++ 应用程序中命令行参数的声明、定义和解析。gflags 库提供了一种简单的方式来添加、解析和文档化命令行标志(flags),使得程序可以根据不同的运行时配置进行调整。

它具有如下几个特点:

  • 易于使用:gflags 提供了一套简单直观的 API 来定义和解析命令行标志,使得开发者可以轻松地为应用程序添加新的参数。
  • 自动帮助和文档:gflags 可以自动生成每个标志的帮助信息和文档,这有助于用户理解如何使用程序及其参数。
  • 类型安全:gflags 支持多种数据类型的标志,包括布尔值、整数、字符串等,并且提供了类型检查和转换。
  • 多平台支持:gflags 可以在多种操作系统上使用,包括 Windows、Linux 和 macOS。
  • 可扩展性:gflags 允许开发者自定义标志的注册和解析逻辑,提供了强大的扩展性。

简而言之gflags的作用就是:简化解析命令行参数的

2.gflags的使用

1.包含头文件

cpp 复制代码
#include <gflags/gflags.h> 

2.定义参数

利用 gflag 提供的宏定义来定义参数。该宏的 3 个参数分别为命令行参数名,参数默认值,参数的帮助信息

cpp 复制代码
DEFINE_string(ip, "127.0.0.1", "这是服务器的监听IP地址,格式: 127.0.0.1");
DEFINE_int32(port, 8080, "这是服务器的监听端口: 8080");
DEFINE_bool(debug_enable, true, "是否调用调试模式,格式为: true/false");

gflags 支持定义多种类型的宏函数

c 复制代码
DEFINE_bool 
DEFINE_int32 
DEFINE_int64 
DEFINE_uint64 
DEFINE_double 
DEFINE_string 

3.访问参数

我们在程序中进行参数的访问时,只需采用以下格式:FLAGS_name

比如上面的例子中,三个命令行参数的访问就是:FLAGS_ip,FLAGS_port,FLAGS_debug_enable

4.初始化参数

cpp 复制代码
google::ParseCommandLineFlags(&argc, &argv, true); 

在main函数中加入这一行即可

5.运行参数设置

gflags 为我们提供了多种命令行设置参数的方式。

string 和 int 设置参数

cpp 复制代码
exec --log_file="./main.log" 
exec -log_file="./main.log" 
exec --log_file "./main.log" 
exec -log_file "./main.log"

bool设置参数

cpp 复制代码
exec --reuse_addr 
exec --noreuse_addr 
exec --reuse_addr=true 
exec --reuse_addr=false

6.配置文件的使用

配置文件的作用是让程序运行参数的配置更标准化,无需每次运行程序时都手动输入每个参数的数值,做到"一次编写,永久使用"。需要注意的是,配置文件中的选项名称必须与代码里定义的选项名称保持一致。

cpp 复制代码
-ip="192.168.113.131"
-port=1234
-debug_enable=false

3.使用样例

main.cc

cpp 复制代码
#include <iostream>
#include <gflags/gflags.h>
using namespace std;

DEFINE_string(ip, "127.0.0.1", "这是服务器的监听IP地址,格式: 127.0.0.1");
DEFINE_int32(port, 8080, "这是服务器的监听端口: 8080");
DEFINE_bool(debug_enable, true, "是否调用调试模式,格式为: true/false");

int main(int argc, char *argv[])
{
    google::ParseCommandLineFlags(&argc, &argv, true);
    cout << FLAGS_ip << endl;
    cout << FLAGS_port << endl;
    cout << FLAGS_debug_enable << endl;
    return 0;
}

main.conf

cpp 复制代码
-ip="192.168.113.131"
-port=1234
-debug_enable=false
cpp 复制代码
./main --help

  Flags from main.cc:
    -debug_enable (是否启用调试模式,格式:true/false) type: bool
      default: true
    -ip (这是服务器的监听IP地址,格式:127.0.0.1) type: string
      default: "127.0.0.1"
    -port (这是服务器的监听端口, 格式:8080) type: int32
      default: 8080
cpp 复制代码
# ./main
127.0.0.1
8080
1
cpp 复制代码
# ./main --flagfile main.conf 
"192.168.1.1"
9090
0

二 gtest介绍和使用

只介绍在项目中我们所用到的部分

1.gtest介绍

GTest 是一个跨平台的 C++单元测试框架,由 google 公司发布。gtest 是为了在不同平台上为编写 C++单元测试而生成的。它提供了丰富的断言、致命和非致命判断、参数化等等测试所需的宏,以及全局测试,单元测试组件。

简单来说就是用于更方便的测试C++代码的

2.gtest的使用

1.头文件包含

cpp 复制代码
#include <gtest/gtest.h> 

2.框架初始化接口

cpp 复制代码
testing::InitGoogleTest(&argc, argv);

3.调用测试样例

cpp 复制代码
RUN_ALL_TESTS(); 

4.TEST宏

cpp 复制代码
//这里不需要双引号,且同测试下多个测试样例不能同名
TEST(测试名称, 测试样例名称)

TEST_F(test_fixture,test_name)
  • TEST:主要用来创建一个简单测试, 它定义了一个测试函数, 在这个函数中可以使用任何 C++代码并且使用框架提供的断言进行检查
  • TEST_F:主要用来进行多样测试,适用于多个测试场景如果需要相同的数据配置的情况, 即相同的数据测不同的行为

5.断言宏

GTest 中的断言的宏可以分为两类:

  • ASSERT_系列:如果当前点检测失败则退出当前函数
  • EXPECT_系列:如果当前点检测失败则继续往下执行

下面是经常使用的断言介绍

cpp 复制代码
// bool 值检查
ASSERT_TRUE(参数),期待结果是 true
ASSERT_FALSE(参数),期待结果是 false

// 数值型数据检查
ASSERT_EQ(参数1, 参数2),传入的是需要比较的两个数  equal
ASSERT_NE(参数1, 参数2),not equal,不等于才返回 true
ASSERT_LT(参数1, 参数2),less than,小于才返回 true
ASSERT_GT(参数1, 参数2),greater than,大于才返回 true
ASSERT_LE(参数1, 参数2),less equal,小于等于才返回 true
ASSERT_GE(参数1, 参数2),greater equal,大于等于才返回 true

3.使用样例

main.cc

cpp 复制代码
#include <iostream>
#include <gtest/gtest.h>
using namespace std;

int Add(int num1, int num2)
{
    return num1 + num2;
}

TEST(Add_test, test1)
{
    ASSERT_EQ(Add(10, 20), 30);
    ASSERT_EQ(Add(20, 20), 40);
}

TEST(string_test, test2)
{
    string str = "hello world";
    EXPECT_EQ(str, "hello world");
}

int main(int argc, char *argv[])
{
    testing::InitGoogleTest(&argc, argv);
    return RUN_ALL_TESTS();
}
cpp 复制代码
g++ -o main main.cc -std=c++17 -lgtest -pthread
cpp 复制代码
[==========] Running 2 tests from 2 test suites.
[----------] Global test environment set-up.
[----------] 1 test from Add_test
[ RUN      ] Add_test.test1
[       OK ] Add_test.test1 (0 ms)
[----------] 1 test from Add_test (0 ms total)

[----------] 1 test from string_test
[ RUN      ] string_test.test2
[       OK ] string_test.test2 (0 ms)
[----------] 1 test from string_test (0 ms total)

[----------] Global test environment tear-down
[==========] 2 tests from 2 test suites ran. (0 ms total)
[  PASSED  ] 2 tests.
相关推荐
Q741_1472 小时前
C++ 位运算 高频面试考点 力扣 268. 丢失的数字 题解 每日一题
c++·算法·leetcode·面试·位运算
电子_咸鱼2 小时前
LeetCode-hot100——验证二叉搜索树
开发语言·数据结构·c++·算法·leetcode·深度优先
Imxyk2 小时前
Codeforces Round 1052 (Div. 2) C. Wrong Binary Searchong Binary Search
c语言·c++·算法
tryCbest2 小时前
Java实现文件下载
java·开发语言
liu****2 小时前
负载均衡式的在线OJ项目编写(五)
运维·c++·负载均衡·个人开发
暖木生晖2 小时前
Javascript变量介绍
开发语言·javascript·ecmascript
心.c3 小时前
JavaScript继承详讲
开发语言·javascript·ecmascript
立方世界3 小时前
【Leaflet.js实战】地图标记与弹窗:从基础到高级的完整实现
开发语言·javascript·ecmascript
saber_andlibert4 小时前
【Linux】深入理解Linux的进程(一)
linux·运维·服务器·开发语言·c++