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

wordpress 单栏优化网站seo公司

wordpress 单栏,优化网站seo公司,乌鲁木齐全网建站,杭州学校网站建设1. 忘掉std::cout吧 我们在学习C时&#xff0c;经常使用std::cout来输出信息&#xff0c;如&#xff1a; std::cout << "Hello World!" << std::endl;这种方式在学习或演示时非常方便&#xff0c;但实际开发中&#xff0c;我们通常会使用一些日志库&am…

1. 忘掉std::cout吧

我们在学习C++时,经常使用std::cout来输出信息,如:

std::cout << "Hello World!" << std::endl;

这种方式在学习或演示时非常方便,但实际开发中,我们通常会使用一些日志库,如:spdlog等。
以下是两者的简单对比:

特性std::coutspdlog
基本定位C++标准库的输出流现代C++日志库
主要用途简单的控制台输出全功能日志记录
性能较慢,特别是默认与C stdio同步时高性能,异步日志支持,优化的格式化
线程安全基本线程安全,但输出可能交错完全线程安全,支持异步日志记录
日志级别无内置日志级别支持多种日志级别(trace, debug, info, warn, error, critical)
格式化使用流操作符和操纵符,格式控制复杂支持Python风格的格式化和fmt库集成,简洁直观
输出目标主要是控制台多种输出目标(控制台、文件、系统日志、网络等)
文件操作需要额外使用std::ofstream内置文件日志支持,自动文件轮换
错误处理通过流状态标志,不直观异常处理和错误回调
内存使用较轻量,但格式化可能导致临时对象创建可配置的内存使用,支持内存池优化
编译依赖C++标准库的一部分,无额外依赖第三方库,需要额外引入
配置灵活性有限,主要通过流操作符高度可配置(日志模式、格式、轮换策略等)
日志轮换不支持支持基于大小和时间的日志轮换
彩色输出不直接支持,需要平台特定代码内置彩色控制台输出支持
模式匹配过滤不支持支持基于模式的日志过滤
国际化支持通过std::locale支持基本Unicode支持
适用场景简单程序、教学示例、快速调试生产环境、复杂应用、需要高级日志功能的系统
代码示例std::cout << "Hello " << name << std::endl;spdlog::info("Hello {}", name);
初始化复杂度低,直接可用中等,需要创建和配置日志器
自定义类型支持通过重载<<运算符通过fmt库的格式化特性

补充说明

何时选择 std::cout

  • 简单的程序或脚本
  • 教学示例和快速原型
  • 不需要复杂日志功能的小型应用
  • 希望减少外部依赖的项目

何时选择 spdlog

  • 生产环境应用
  • 需要高性能日志记录的系统
  • 多线程应用
  • 需要日志轮换和多目标输出的项目
  • 对日志格式和级别有严格要求的场景

性能优化提示

  • 对于 std::cout,可以使用 std::ios::sync_with_stdio(false) 提高性能
  • 对于 spdlog,可以配置异步日志和自定义线程池以获得最佳性能

我个人建议,无论是简单的程序还是复杂的应用,都使用spdlog,因为spdlog功能强大,配置灵活,而且性能高。

1.1. spdlogfmt

通常 spdlogfmt结合使用,fmt是一个现代的C++格式化库,它提供了类似于Python的格式化语法,可以简化日志格式化。

1.1.1. 安装

# 通过vcpkg安装
vcpkg install spdlog fmt

1.1.2. fmt代码示例

#include <fmt/core.h>
#include <fmt/format.h>
int main() {int year = 2025;std::string name = "Vulkan";// 基本格式化输出fmt::print("Hello, {}!\n", name);// 格式化数字fmt::print("The year is {}.\n", year);// 格式化到字符串std::string message = fmt::format("Welcome to {} cookbook, year {}.", name, year);fmt::print("{}\n", message);return 0;
}

1.1.3. spdlog 代码示例

简单使用

#include <spdlog/spdlog.h>
int main(){spdlog::info("Hello, {}!", "World");
}

按天生成日志文件

#include <spdlog/spdlog.h>
#include <spdlog/sinks/daily_file_sink.h>void daily()
{fs::create_directories("logs");auto logger = spdlog::daily_logger_mt("daily_logger", "logs/daily.txt", 0, 0);logger->info("Hello, {}!", "Vulkan");spdlog::set_default_logger(logger);spdlog::info("The year is {}", 2025);
}

将日志输出到控制台和文件

#include <spdlog/spdlog.h>
#include <spdlog/sinks/basic_file_sink.h>
#include <spdlog/sinks/stdout_color_sinks.h>
#include <spdlog/sinks/daily_file_sink.h>void multi_sink()
{// 创建控制台 sinkauto console_sink = std::make_shared<spdlog::sinks::stdout_color_sink_mt>();// 创建文件 sinkauto file_sink = std::make_shared<spdlog::sinks::basic_file_sink_mt>("log.txt", true);// 创建多 sink loggerstd::vector<spdlog::sink_ptr> sinks{console_sink, file_sink};auto logger = std::make_shared<spdlog::logger>("multi_sink", sinks.begin(), sinks.end());spdlog::set_default_logger(logger);spdlog::info("Hello, {}!", "Vulkan");spdlog::warn("This is a warning!");spdlog::error("This is an error!");spdlog::info("The year is {}", 2025);spdlog::shutdown();
}

1.1.4. CMakeLists.txt

以下是一个示例配置:
我们采用find_package(fmt CONFIG REQUIRED)来进行配置

cmake_minimum_required(VERSION 3.10)# 设置项目名称和语言
project(VulkanChecker LANGUAGES CXX)# 设置C++标准
set(CMAKE_CXX_STANDARD 17)
set(CMAKE_CXX_STANDARD_REQUIRED ON)find_package(fmt CONFIG REQUIRED)
find_package(spdlog CONFIG REQUIRED)# 添加可执行文件
add_executable(main main.cpp)target_link_libraries(main PRIVATE fmt::fmt)
target_link_libraries(main PRIVATE spdlog::spdlog)# 如果是Windows系统,设置可执行文件的输出目录
if(WIN32)set_target_properties(mainPROPERTIESRUNTIME_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/bin")
endif()

1.1.5. windows 下编译配置 与 运行

# 生成构建目录并配置CMake工程
cmake -B build -S . -DCMAKE_TOOLCHAIN_FILE=C:/Users/Admin/workspace/vcpkg/scripts/buildsystems/vcpkg.cmake# 编译工程,若成功则运行生成的可执行文件
cmake --build build ; if ($?) { .\build\bin\Debug\main.exe | Tee-Object -FilePath output.txt}

以下是一个输出结果示例:

[2025-05-20 06:26:16.578] [daily_logger] [info] Hello, Vulkan!
[2025-05-20 06:26:16.578] [daily_logger] [info] The year is 2025

由此可以看出,spdlog 会自动按天生成日志文件,且日志文件中包含时间戳、日志等级、日志内容。

http://www.dtcms.com/wzjs/43074.html

相关文章:

  • 网站建设品牌推广seo网络推广培训去哪里好
  • 做网站要源代码近期国际新闻20条
  • 网站pc和手机端分离怎么做百度推广登录网址
  • 互联网公司网站模板南京seo推广公司
  • 最好的餐饮设计网站建设东莞企业网站排名优化
  • 维基百科建设网站可以免费网络推广网站
  • 太原做网站个人长沙网址seo
  • 网站开发可以当程序员新东方烹饪学校
  • 常见的网站名称有哪些沈阳企业网站seo公司
  • 扁平化企业网源码win8风格精简化源码asp带后台企业网站自己怎么做网址开网站
  • 电脑机箱定制网站百度客户电话
  • 建站之星 网站排名seo是什么意思广东话
  • Wordpress上传万网空间唐山百度seo公司
  • 深圳有哪些网站开发公司媒介平台
  • 武汉做网站网络公司百度竞价开户流程
  • 重庆定制网站开发价格西安网站维护
  • python做调查问卷网站网络营销产品策略分析
  • 网站建设类公司新闻推销产品怎么推广
  • 地方性资讯门户网站裂变营销五种模式十六种方法
  • 新闻网站传播力建设怎么在腾讯地图上添加自己的店铺
  • 部署自己做的网站吗十大经典案例
  • 个人网站怎么备案可以做哪些哈尔滨网站建设
  • wordpress进销存插件南昌seo
  • 广西省建设厅网站seo推广的常见目的有
  • 武汉便宜做网站360搜索推广官网
  • b站推广网站入口mmm网站开发的步骤
  • 深圳专业政府网站建设东莞seo搜索
  • 动态网站开发实训报告6如何分析百度指数
  • 网站开发总结与未来展望四川游戏seo整站优化
  • 安庆网站建设为中国旺旺(00151) 股吧