Sylar C++高性能服务器学习记录03 【配置系统-知识储备篇】

早在19年5月就在某站上看到sylar的视频了,一直认为这是一个非常不错的视频,还有幸加了sylar本人的wx,由于本人一直是自学编程,基础不扎实,也没有任何人的督促,没能坚持下去,每每想起倍感惋惜。恰逢互联网寒冬,在家无事,遂提笔再续前缘。

为了能更好的看懂sylar,本套笔记会分两步走,每个系统都会分为两篇博客。
分别是【知识储备篇】和【代码分析篇】
(ps:纯粹做笔记的形式给自己记录下,欢迎大家评论,不足之处请多多赐教)

配置系统-知识储备

知识点01 (boost库的安装)

boost是一个非常强大的库,sylar配置系统中用到了boost库的类型转换功能,所以我们需要提前安装一下:

去官网下载库压缩包文件 boost_x_x_x.tar.gz

//如果你是在服务器上操作的,可以在网页中鼠标移动到对应压缩包上右键复制下载地址然后使用
wget https://sourceforge.net/projects/boost/files/boost/1.61.0/boost_1_61_0.tar.gz
//解压:
tar -zxvf boost_x_x_x.tar.gz
//进入解压后的文件夹:
cd boost_x_x_x
//运行脚本,如果没有权限请先赋权:chmod +x ./bootstrap.sh 
./bootstrap.sh 
//运行脚本:.
/b2 install

这样你的boost库安装好了,速度取决于你的机器好坏,总之挺久的。
当然你可以yum安装

yum install -y boost boost-devel

以下可以测试以下你的boost是否安装成功

#include <boost/version.hpp>
#include <boost/config.hpp>
int main(int argc,char** argv){cout << BOOST_VERSION <<endl;cout << BOOST_LIB_VERSION<<endl; cout << BOOST_STDLIB <<endl;cout <<BOOST_PLATFORM <<endl;cout << BOOST_COMPILER<<endl;
}

lexical_cast的作用
lexical_cast使用统一的接口实现字符串与目标类型之间的转换。

#include "iostream"
#include "boost/lexical_cast.hpp" // 需要包含的头文件int main(){char* p="32768";int i=0;// 将字符串转化为整数i=boost::lexical_cast<int>(p); std::cout << i << std::endl;return i;
}

知识点02 (yaml-cpp的安装与使用)

由于我们的配置系统是基于yaml的,所以我们需要安装对应c++的库。

//我这里指定了 Tag 因为我的cmake用的 2.8的
git clone -b yaml-cpp-0.6.0 --single-branch https://github.com/jbeder/yaml-cpp.git
cd yaml-cpp
mkdir build
cd build
cmake -DBUILD_SHARED_LIBS=ON ..    //-DBUILD_SHARED_LIBS=ON 启用动态库
make -j
make install

接下来是CMakeLists的配置这里直接拿sylar的配置

cmake_minimum_required(VERSION 2.8)
project(sylar)include (cmake/utils.cmake)set(CMAKE_VERBOSE_MAKEFILE ON)
set(CMAKE_CXX_FLAGS "$ENV{CXXFLAGS} -rdynamic -O0 -ggdb -std=c++11 -Wall -Wno-deprecated -Werror -Wno-unused-function -Wno-builtin-macro-redefined")include_directories(.)
include_directories(/apps/sylar/include)
link_directories(/apps/sylar/lib)find_library(YAMLCPP yaml-cpp)add_executable(test_config tests/test_config.cc)
target_link_libraries(test_config ${YAMLCPP})SET(EXECUTABLE_OUTPUT_PATH ${PROJECT_SOURCE_DIR}/bin)
SET(LIBRARY_OUTPUT_PATH ${PROJECT_SOURCE_DIR}/lib)

接下来我们创建一个test.yaml文件用来测试

name: XYZ
sex: male
age: 30
system:port: 0value: 0int_vec: [10, 20]

接下来我们在 test_config.cc中做测试

#include <yaml-cpp/yaml.h>
#include <iostream>int main(int argc,char** argv){YAML::Node node = YAML::LoadFile("/apps/sylar/bin/conf/test.yaml");std::cout << node["name"].as<std::string>() << std::endl;std::cout << node["sex"].as<std::string>() << std::endl;std::cout << node["age"].as<int>() << std::endl;//18std::cout << node["system"]["port"].as<std::string>() << std::endl;std::cout << node["system"]["value"].as<std::string>() << std::endl;for(auto it = node["system"]["int_vec"].begin(); it != node["system"]["int_vec"].end(); ++it){std::cout << *it <<“ ”;}std::cout << std::endl;return 0;
}

以下是输出:

XYZ
male
30
0
0
10 20

此时证明yaml-cpp已经可以正常使用了

知识点03 (find_first_not_of 与 find_last_not_of 的使用)

1.find_first_not_of()函数
正向查找在原字符串中第一个与指定字符串(或字符)中的任一字符都不匹配的字符,返回它的位置。若查找失败,则返回npos。(npos定义为保证大于任何有效下标的值。)

#include <iostream>
#include <string>int main(){std::string prefix="xyz";std::string str="abcd";if(prefix.find_first_not_of(str)!=std::string::npos){std::cout << prefix << " is not in " << str;}return 0;
}

2.find_last_not_of()函数
正向查找在原字符串中最后一个与指定字符串(或字符)中的任一字符都不匹配的字符,返回它的位置。若查找失败,则返回npos。(npos定义为保证大于任何有效下标的值。)

#include <iostream>
#include <string>int main(){std::string prefix="xyz";std::string str="abcd";if(prefix.find_last_not_of(str)!=std::string::npos){std::cout << prefix << " is not in " << str;}return 0;
}

知识点04 (模板泛化,模板全特化,模板偏特化)

1.什么是模板类?
在 C++ 中,模板类是一种通用的类模板,允许我们定义一种可以用于多种数据类型的类。通过使用模板类,我们可以在不重复编写代码的情况下创建适用于不同类型的类实例。

2.模板类的(泛化,全特化,偏特化)

//1.泛化的Test类模板
template<class T, class U>
class Test	{Test(){cout << "泛化版本的构造函数" << endl;}void Func(){cout << "泛化版本" << endl;}
};//2.全特化的Test类模板
//当T和U这两个类型模板参数都为int类型时,做一个特化版本
//全特化:就是所有类型模板参数(这里T 和 U),都用具体类型代表
template<>	//全特化:所有类型模板参数都用具体类型代表,所以这里的template后面的<>里就为空
class Test<int,int>	//上边的T绑定到这里的第一个int,上边的U绑定到这里的第二个int
{Test(){cout << "int , int的特化版本构造函数" << endl;}//可以该特化版本进行单独处理void Func(){cout << "int , int的特化版本" << endl;}
};template<>	//全特化:所有类型模板参数都用具体类型代表,所以这里的template后面的<>里就为空
class Test<double, int>	//上边的T绑定到这里的第一个int,上边的U绑定到这里的第二个int
{Test(){cout << "double , int的特化版本构造函数" << endl;}//可以该特化版本进行单独处理void Func(){cout << "double , int的特化版本" << endl;}
};//3.偏特化的类模板
//从参数数量上进行偏特化,现在绑定两个类型模板参数
template<typename U>	//留一个U类型模板参数
class Test<int, U, double>{void Func() { cout << "偏特化int ,U, double版本" << endl; }
};

3.模板函数的(泛化,全特化)

//泛化版本
template<typename T, typename U>
void Func(const T& a, const U& b){cout << "Func()泛化版本" << endl;cout << a << " " << b << endl;
}
//全特化版本
template<>
void Func(const int& a, const double& b){cout << "Func()int,double 全特化版本" << endl;cout << a << " " << b << endl;
}
//偏特化版本(不支持!!!)int main(){const char* p = "I Love China";int a = 12;Func(p, a);//全特化函数模板实际上等价于实例化一个函数模板,并不是等级一个函数重载Func(15, 25.3);	//特化版本return 0;
}

4.模板类作为函数返回对象时需要 typename 修饰

templete<class T>
typename Test<T> func(){return new Test<T>();
}

5.模板类作为类型定义时需要 typename 修饰

typename Test<T> t = new Test<T>();

模板特化相关知识点非常多,这里只是做简单了解,需要深入了解可以自行学习。

知识点05 (dynamic_pointer_cast)

std::dynamic_pointer_cast<目标类型>(被转换智能指针)
接受一个被转换的智能指针和目标类型的指针类型作为参数,并返回一个新的智能指针。
dynamic_pointer_cast只适用于std::shared_ptr和std::weak_ptr类型的智能指针,用于进行智能指针的动态类型转换。

#include <iostream>
#include <memory>struct Base {virtual ~Base() {}
};struct Derived : public Base {void foo() {std::cout << "Derived::foo() called" << std::endl;}
};int main() {std::shared_ptr<Base> basePtr = std::make_shared<Derived>();std::shared_ptr<Derived> derivedPtr = std::dynamic_pointer_cast<Derived>(basePtr);if (derivedPtr) {derivedPtr->foo();} else {std::cout << "Failed to perform dynamic cast" << std::endl;}return 0;
}

知识点06 (::tolower 与 ::toupper)

#include <iostream>int main(int argc, char** argv) {string str="abcDEF";for(int i=0;i<str.length();i++){str[i]=::tolower(str[i]);   }std::cout<<str<<std::endl;   //abcdeffor(int i=0;i<str.length();i++){str[i]=::toupper(str[i]);   }std::cout<<str<<std::endl;   //ABCDEFreturn 0;
}

知识点07 (std::transform)

使用该函数,必须添加包含算法库“algorithm”。
它接受四个参数:
1:输入范围的起始迭代器。
2:输入范围的结束迭代器。
3:输出范围的起始迭代器。
4:一个一元操作函数,用于对输入范围内的每个元素进行处理。

std::vector<int> nums = {1, 2, 3, 4, 5};
std::vector<int> result(nums.size());
std::transform(nums.begin(), nums.end(), result.begin(), [](int x) { return x * 2; });//结合 ::tolower 
std::string str="aBcDef";
std::transform(str.begin(), str.end(), str.begin(), ::tolower);
std::cout << str << std::endl;	//abcdef

知识点08 (仿函数)

仿函数是一个类或结构体,它重载了operator()运算符,使其可以像函数一样被调用。
仿函数的实例可以像函数指针一样传递给STL算法或容器的操作,从而实现自定义行为。
比如下面这个,Less是一个仿函数,它接受两个参数并返回"<"比较的结果。

template<class T>
class Less {
public:bool operator()(const T& x, const T& y){return x < y;}
};

接下来可以看下【配置系统-代码分析篇】
求关注:持续更新…

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/2101.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

4.22-访亲戚有感

昨天&#xff0c;4.2&#xff0c;因我要求于亲戚&#xff0c;当然&#xff0c;亲戚也是很大方&#xff0c;帮了我的忙。在中午吃饭的时候&#xff0c;于是乎闲聊起来了&#xff0c;在我的眼中她是一个非常成功的人&#xff0c;现在的资产&#xff0c;对于她来说&#xff0c;躺平…

力扣数据库题库学习(4.22日)

577. 员工奖金 问题链接 思路分析 Employee表与Bonus表通过empId字段可以连接&#xff0c;需求是查出奖金少于1000的员工名和奖金值。 这里奖金少于1000的情况就是没有奖金有奖金但少于1000 这里我给出的解决方案就是使用左连接&#xff0c;将Employee表作为左表&#xff…

arm架构,django4.2.7适配达梦8数据库

【Python相关包版本信息】 Django 4.2.7 django-dmPython 3.1.7 dmPython 2.5.5 【达梦数据库版本】 DM Database Server 64 V8 DB Version: 0x7000c 适配过程中发现的问题如下&#xff1a; 错误一&#xff1a;d…

解决IDEA调试方法进不去与数据看不到的问题

问题场景&#xff1a; 最近使用IDEA调试的时候&#xff0c;发现JDK有些方法**步进(F7)**无法进入&#xff0c;有些类的字段值也看不到。 原因分析&#xff1a; 提示&#xff1a;IDEA为了提升调试效率&#xff0c;以及突出调试数据的显示效果&#xff0c;会默认帮我们做一些筛选…

PAT——1007素数对猜想(C++)

问题描述&#xff1a; 让我们定义为&#xff1a;​&#xff0c;其中​是第i个素数。显然有d1​1&#xff0c;且对于n>1有​是偶数。“素数对猜想”认为“存在无穷多对相邻且差为2的素数”。 现给定任意正整数 N (<10^5)&#xff0c;请计算不超过 N 的满足猜想的素数对的个…

# 从浅入深 学习 SpringCloud 微服务架构(四)Ribbon

从浅入深 学习 SpringCloud 微服务架构&#xff08;四&#xff09;Ribbon 段子手168 一、ribbon 概述以及基于 ribbon 的远程调用。 1、ribbon 概述&#xff1a; Ribbon 是 Netflixfa 发布的一个负载均衡器,有助于控制 HTTP 和 TCP客户端行为。 在 SpringCloud 中 Eureka …

ubuntu 23.04 Dell T3660 听歌没声音的尝试

首先&#xff0c;还是要安装PulseAudio Volume Control sudo apt install pulseaudio 或者 snap install pulseaudio 装了pulseaudio可以在configure和playback间切换选择用哪个声卡输出声音&#xff0c;一般选Stereo Analog Output 网上其他办法也可以试试&#xff0c;比…

STM32 CAN发送邮箱和接收FIFO

STM32的CAN发送邮箱和接收FIFO CAN发送邮箱 CAN外设一共有3个发送邮箱&#xff0c;即最多可以缓存3个待发送的报文。每个发送邮箱中包含有标识符寄存器CAN_TIxR、数据长度控制寄存器CAN_TDTxR及2个数据寄存器CAN_TDLxR、 CAN_TDHxR&#xff0c;它们的功能如下&#xff1a; 寄…

Flutter 插件站新升级: 加入优秀 GitHub 开源项目

Flutter 插件站新升级: 加入优秀 GitHub 开源项目 视频 https://youtu.be/qa49W6FaDGs https://www.bilibili.com/video/BV1L1421o7fV/ 前言 原文 https://ducafecat.com/blog/flutter-awesome-github-repo-download 这几天晚上抽空把 Flutter 插件站升级&#xff0c;现在支…

qt实现不定数量的按钮向前向后移动展示

按钮模拟移动 引言示例代码第一种思路开发环境代码结构实现代码第二种思路开发环境实现代码第三种思路开发环境实现代码总结引言 此文主要记录用qt实现按钮的移动,具体效果如下: 模拟按钮移动效果 示例代码 本文记录了三种实现方式。 第一种 思路 用动态数组vector存放创…

【python项目推荐】键盘监控--统计打字频率

原文&#xff1a;https://greptime.com/blogs/2024-03-19-keyboard-monitoring 代码&#xff1a;https://github.com/GreptimeTeam/demo-scene/tree/main/keyboard-monitor 项目简介 该项目实现了打字频率统计及可视化功能。 主要使用的库 pynput&#xff1a;允许您控制和监…

【多线程】synchronized原理 | 锁升级| 锁消除 | 锁粗化 | 信号量 | CountDownLatch

文章目录 一、synchronized原理synchronized属于哪种锁&#xff1f; 1.锁升级偏向锁&#xff1a; 2.锁消除3.锁粗化锁的粒度 二、信号量 Semaphore三、CountDownLatch1.await方法2.countDown方法 一、synchronized原理 synchronized属于哪种锁&#xff1f; ​ 在初始情况下&am…

【oceanbase】安装ocp,ocp部署oceanbase

https://www.oceanbase.com/docs/common-ocp-1000000000584989 资源 iphostnamecpumem组件192.168.0.71obnode-000-071816oceanbase-ce192.168.0.72obnode-000-072816oceanbase-ce192.168.0.73obnode-000-073816oceanbase-ce192.168.0.74obproxy-000-07424obproxy-ce192.168.0…

【Java EE】网络初识

目录 1.网络发展史 2.局域网LAN 2.1组建方式 2.1.1基于网线直连 2.1.2基于集线器组建 2.1.3基于交换机组建 2.1.4基于交换机和路由器组建 3.广域网WAN 4.网络通信基础 4.1 IP地址 4.1.1概念 4.1.2格式 4.1.3端口号 4.1.3.1概念 4.1.3.2格式 4.2认识协议 4.2.1概…

算法矩阵提速原理

不管是图形还是AI&#xff0c;如果看过相关的算法&#xff0c;都会注意到矩阵运算&#xff0c;很多讲算法的教程都会说将for转换成矩阵&#xff0c;可以极大的增加效率。 但是这不是为难我们这些数学低能儿吗&#xff1f;矩阵运算这些高级货算是高级数学了&#xff0c;比CURD还…

Qt 跨平台开发的一丢丢总结

Qt 跨平台开发 文章目录 Qt 跨平台开发摘要第一 \ & /第二 神奇{不能换行显示第三 预处理宏 关键字&#xff1a; Qt、 win、 linux、 lib、 MSVC 摘要 最近一直在琢磨Qt跨平台开发的问题&#xff0c;缘由有以下几个&#xff0c; 首先第一个&#xff0c;我们目前开发…

医院敏感文件交互 如何保障安全和效率?

医院会产生大量的敏感文件&#xff0c;这些敏感文件交互时&#xff0c;都需要使用特殊的手段&#xff0c;来保障数据的安全性。 医院的敏感数据主要包括以下几类&#xff1a; 1、患者基本信息&#xff1a;包括患者的姓名、身份证号码、户籍地或现住址、联系方式、文化程度、既…

docker基础知识-01

Docker是什么 Docker是一个开源的容器化平台&#xff0c;用于开发、打包和运行应用程序。它允许开发者将应用程序及其所有依赖项打包到一个可移植的容器中&#xff0c;然后可以在任何支持Docker的环境中运行。Docker的主要优势是可以在不同的操作系统、云服务和物理机上快速、…

【数据结构】二叉树链式结构的实现《遍历,实现》(题库+解析+源码)

前言 二叉树的学习离不开对堆的理解&#xff0c;这是上篇堆的传送门 http://t.csdnimg.cn/F6Jp3 1.二叉树链式结构的实现 1.1 前置说明 在学习二叉树的基本操作前&#xff0c;需先要创建一棵二叉树&#xff0c;然后才能学习其相关的基本操作。由于现在大家对二 叉树结构掌握还…

【LLM】向量知识库

文章目录 认识向量知识库向量Embeddings向量数据库向量数据库的作用向量数据库与传统数据库的区别 Embedding API使用公有Embedding API自定义一个Embeedding API 常见文本数据的预处理搭建并使用向量数据库思考向量数据库在LLM中的价值体现向量的妙用&#xff0c;可行&#xf…