当前位置: 首页 > news >正文

C++服务器框架开发9——日志系统LogFormatter_4/各个类的关系梳理/std::function/std::get

该专栏记录了在学习一个开发项目的过程中遇到的疑惑和问题。
其教学视频见:[C++高级教程]从零开始开发服务器框架(sylar)

上一篇:C++服务器框架开发8——日志系统LogFormatter_3/override/宏定义优化switchcase结构

C++服务器框架开发9——日志系统LogFormatter_4/各个类的关系梳理/std::function/std::get

  • 目前进度
  • 关系梳理
  • std::function学习
  • std::get学习

目前进度

学习完第5个视频。下一节是编译调试,我也会在下篇文章把这1~9的所有代码给出。
要点:

  1. log.h中,LogAppender的log函数加了一个指针logger,目的是为了把log的名字传进去,因为在formatter中有输出日志名称的功能;Logger加了一个函数getName(),这个函数就是为了LogAppender加的那个指针logger能够调用这个函数来获取到日志名称。
    在这里插入图片描述

  2. 相应的,对LogAppender的子类StdoutLogAppender和FileLogAppender的函数log做修改,对LogFormatter::format也对应做修改,下图是log.cc中的修改。但实际在log.h中也要做给这几个类的函数的形式参数做相应修改(该up可能忘记了)
    在这里插入图片描述

  3. 在log.cc中,实现各个FormatItem的子类,并将它们的位置改放到了logger::ToString函数的下方。其中的第2个ElapseFormatItem是写错了,应该是NameFormatItem。
    在这里插入图片描述在这里插入图片描述
    在这里插入图片描述

  4. 在log.h中给FormatItem加了一个带参数的构造函数。
    在这里插入图片描述

  5. 在log.cc中的LogFormatter::init后面加上如下的264~293行的内容。之前C++服务器框架开发7中的vec存入了LogFormater::m_pattern中的所有要解析的内容,然后现在要调用各个Item子类对象来格式化,并将内容存入LogMatter::m_items中。
    在这里插入图片描述

关系梳理

目前在logger中实现的类有logger、LogAppender、LogFormatter,及它们的子类。比较复杂的是各种log和format函数,所以有必要梳理一下它们的关系。
它们各自的成员,大致的调用关系如下图:
在这里插入图片描述

std::function学习

要点5中出现了std::function,学习下它。参考字文章1。
std::function是函数包装器,可包装任何类型的可调用实体,包含在头文件<functional>中。
例子:std::function包装lamda表达式

#ifndef __HELLOWORLD__
#define __HELLOWORLD__
#include<iostream>
#include<functional>#endif std::function<int(int)> callback;
int main() {std::cout << "Hello world" << std::endl;auto fun3 = [](int a) {return a * 2; }; //lamda表达式callback = fun3; //std::function包装lamda表达式std::cout << callback(9) << std::endl; //std::function对象实例调用包装的调用实体return 0;
}

在这里插入图片描述

std::get学习

要点5中,用这个读取vec里面的std::tuple。
参考自文章2。

  1. 在之前的文章C++11 std::tuple 中有使用std::get获取std::tuple元素的例子。
  2. std::get除了通过索引(C++11)获取std::tuple的元素,还能通过元素类型获取元素
#ifndef __HELLOWORLD__
#define __HELLOWORLD__
#include<iostream>
#include<tuple>
#include<string>#endif int main()
{std::tuple<int, int> t1{ 1, 1 };std::cout << "t1 is {" << std::get<0>(t1) << ", " << std::get<1>(t1) << "}" << std::endl;std::tuple<int, std::string> t2{ 1, "hello world" };std::cout << "t2 is {" << std::get<int>(t2) << ", " << std::get<std::string>(t2) << "}" << std::endl;std::tuple<int, int> t3{ 1, 1 };// error: static_assert failed due to requirement 'value != __ambiguous' // "type occurs more than once in type list"// std::cout << "t3 is {" << std::get<int>(t3);return 0;
}

在这里插入图片描述

http://www.lryc.cn/news/92058.html

相关文章:

  • arm平台上的MNN编译与运行
  • python 编译安装指定版本 for linux
  • 在Linux系统下基于Docker搭建Redis集群
  • 牛客网刷题Day5
  • Vue.js 中的动态组件是什么?如何使用动态组件?
  • 2023年京东618预售数据:传统滋补成预售黑马,预售额超27亿
  • 【Linux系统基础快速入门详解】Linux 常用文件过滤编辑命令原理详解和每个命令使用场景以及实例
  • 05WEB系统的通信原理图
  • 降低试错成本,低代码或成企业数字化转型突破口
  • 串口助手(串口发送接收数据, 定时, 清空, hex显示)
  • bp神经网络
  • strace交叉编译后对特定文件的写流程进行监控和过滤
  • 初识网络之TCP网络套接字
  • 自然语言处理从入门到应用——自然语言处理的基本问题:文本分类(Text Classification, Text Categorization)
  • 【论文】——Robust High-Resolution Video Matting with Temporal Guidance浅读
  • 第四章、用户体验五要素之范围层解析(本文作用是通俗讲解,让你更容易理解)
  • 计算机毕业论文内容参考|基于python的农业温室智能管理系统的设计与实现
  • Java 进阶 -- 流
  • 硬件 TCP/IP 协议栈
  • word恢复和粘贴按钮变灰色,不可用怎么办?
  • 【unity技巧】Physics2D Raycast、Overlapcircle、OverlapBox检测的用法
  • 一、kafka入门
  • 公司新来一00后,真让人崩溃...
  • (1Gb)S28HS01GTGZBHA030/ S28HS01GTGZBHV033/ S28HS01GTGZBHA033 FLASH - NOR闪存器件
  • 苹果服务端通知v2处理(AppStore Server Notifications V2)
  • matlab 道路点云路缘石边界提取
  • 二叉树详解:带你掌握二叉树
  • LNMP网站框架搭建(编译安装)
  • 详解Servlet API
  • 【小白教程】Docker安装使用教程,以及常用命令!