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- 文档站: https://lessup.github.io/cpp-high-performance-guide/
- 学院:
docs/zh/academy/index.md - 架构:
docs/zh/architecture/index.md - 实践手册:
docs/zh/playbook/index.md - 参考:
docs/zh/reference/index.md - 研究:
docs/zh/research/index.md - 实践手册内的快速开始:
docs/zh/getting-started/quickstart.md - 学习路径:
docs/zh/guides/learning-path.md - 性能分析指南:
docs/zh/guides/profiling-guide.md - 验证与 Sanitizer:
docs/zh/guides/validation.md - 英文入口:
README.md与docs/en/
- 语言: C++20
- 构建: CMake 3.22+、Ninja
- 测试: Google Test、RapidCheck
- 基准测试: Google Benchmark
- 文档: VitePress + GitHub Pages
- 性能分析: perf、FlameGraph、Valgrind、VTune
贡献流程、hooks 配置与 OpenSpec 约定见 CONTRIBUTING.zh.md。