Skip to content

Latest commit

 

History

History
103 lines (79 loc) · 4.06 KB

File metadata and controls

103 lines (79 loc) · 4.06 KB

C++ 高性能指南

Stars CI License

English | 简体中文 | GitHub Pages | Discussions

通过可运行示例、基准测试和 VitePress 文档站,学习可验证的现代 C++20 性能工程。

这个仓库解决什么问题

这个项目关注那些“很容易被谈论、但不容易被验证”的 C++ 性能主题:

  • 现代 CMake 与 preset 驱动的构建流程
  • 内存与缓存布局取舍
  • 现代 C++ 的性能实践
  • SIMD 与向量化
  • 并发与无锁基础
  • 基于 benchmark 与 profiling 的性能分析

每个主题都尽量做到 可阅读、可构建、可测量

你可以从哪里开始

区域 内容
examples/01-cmake-modern/ 现代 CMake 结构与反模式
examples/02-memory-cache/ AOS vs SOA、伪共享、对齐、预取
examples/03-modern-cpp/ constexpr、移动语义、reserve、ranges
examples/04-simd-vectorization/ 自动向量化、intrinsics、SIMD 封装
examples/05-concurrency/ 原子操作、无锁队列、OpenMP
docs/ 双语 Pages 白皮书,覆盖学院 / 架构 / 实践手册 / 参考 / 研究

快速开始

git clone https://github.com/LessUp/cpp-high-performance-guide.git
cd cpp-high-performance-guide

cmake --preset=release
cmake --build build/release

运行一个 benchmark:

./build/release/examples/02-memory-cache/aos_soa_bench

如果你想在快速开始之后进入新的文档主路径,请先查看 docs/zh/playbook/index.md,再进入 docs/zh/guides/validation.md 了解 sanitizer 相关说明。

常用验证命令

cmake --preset=debug && cmake --build build/debug && ctest --preset=debug
cmake --preset=release && cmake --build build/release && ctest --preset=release

cmake --preset=asan && cmake --build build/asan && ctest --preset=asan
cmake --preset=tsan && cmake --build build/tsan && ctest --preset=tsan
cmake --preset=ubsan && cmake --build build/ubsan && ctest --preset=ubsan

文档入口

技术栈

  • 语言: C++20
  • 构建: CMake 3.22+、Ninja
  • 测试: Google Test、RapidCheck
  • 基准测试: Google Benchmark
  • 文档: VitePress + GitHub Pages
  • 性能分析: perf、FlameGraph、Valgrind、VTune

贡献

贡献流程、hooks 配置与 OpenSpec 约定见 CONTRIBUTING.zh.md