0

0

如何使用Folly库提升c++服务性能? (Facebook开源库)

尼克

尼克

发布时间:2026-01-20 09:53:02

|

376人浏览过

|

来源于php中文网

原创

Folly不会自动提升性能,需按高吞吐低延迟场景选对组件:如folly::ConcurrentHashMap替代加锁unordered_map、IOBuf减少拷贝、fbstring优化字符串操作,并注意编译链接要求与使用陷阱。

如何使用folly库提升c++服务性能? (facebook开源库)

直接用 Folly 不会自动提升性能,它只是把 Facebook 高并发服务里反复验证过的高性能 C++ 组件打包给你——关键在选对组件、避开默认陷阱、适配你的数据模式。

什么时候该用 Folly 而不是标准库

不是所有场景都适合。Folly 的优势集中在高吞吐、低延迟、多线程共享数据的后端服务中:

  • 你需要 folly::ConcurrentHashMap 替代 std::unordered_map + 手动加锁,且读远多于写
  • 你在做大量短生命周期对象分配(比如每请求一个 buffer),folly::IOBufstd::vector 减少拷贝和内存碎片
  • 你用 std::string 做频繁拼接或子串切片,folly::fbstring 的 SSO 和引用计数能省掉不少 malloc
  • 你在写异步网络层,folly::EventBase + folly::AsyncSocket 比裸 epoll + std::thread 更易控资源

folly::IOBuf 怎么避免“越用越慢”?

IOBuf 是零拷贝核心,但误用反而增加开销:

  • 不要对小数据(folly::fbstring 或数组更轻量
  • 调用 coalesce() 前先检查 isChained(),链式 IOBuf 合并会触发内存拷贝,高频路径慎用
  • 从 socket 读取时优先用 IOBuf::createCombined() 预分配多段缓冲,避免后续追加时反复 realloc
  • 释放 IOBuf 链时,确保所有持有者都已 drop 引用 —— 循环引用或提前析构会导致内存泄漏(常见于 callback 捕获 IOBuf 智能指针)
auto buf = folly::IOBuf::create(4096);
buf->append(1024);
// ✅ 正确:复用同一块内存
memcpy(buf->writableData(), data, 1024);
buf->append(1024);

// ❌ 错误:触发内部 realloc
buf->advance(2048);
buf->prepend(512); // 可能移动数据

folly::ConcurrentHashMap 的 key 类型陷阱

它不接受任意 std::hash,必须满足两个隐含条件:

立即学习C++免费学习笔记(深入)”;

千博企业网站管理系统个人SQL版20120128
千博企业网站管理系统个人SQL版20120128

千博企业网站管理系统个人版免费下载、免费使用、功能无限制,完全免费拥有(请尊重开发者版权,保留首页底部版权显示):内含Flash动画源码、Access数据库程序包、SQL数据库程序包。 千博企业网站管理系统个人版特点: 1.全站模块化操作,静态标签调用,更强扩展性… 千博企业网站系统个人版是一套基于.Net + Access(SQL)建站管理系统软件、不依赖于服务商特定空间、不需安装任何空间商组

下载
  • key 类型必须支持 trivial copy(POD 或显式标记 std::is_trivially_copyable_v),否则运行时报 static_assert 失败
  • hash 函数不能抛异常 —— 默认用 std::hash,但若自定义 key 用了 std::string 成员,需重载 hash::operator() 并确保不抛异常
  • 迭代器不是强一致性:遍历时插入/删除可能跳过或重复元素,别依赖“全量快照”语义
  • 桶数量(initialCapacity)建议设为 2 的幂,且至少是预期 size 的 2–3 倍,否则锁争用上升明显

性能敏感路径上,如果 key 是整数或固定长字符串,直接用 uint64_tfolly::StringPiece,比 std::string 少一次堆分配。

编译和链接最容易漏的三件事

Folly 对构建环境要求比一般库高,没配好会静默降级或链接失败:

  • 必须启用 C++17(-std=c++17),部分组件如 folly::Synchronized 依赖 std::shared_mutex
  • 链接时要加 -lfolly -lglog -lgflags -lboost_context -lboost_thread,缺 glog 会导致日志组件 fallback 到 stderr,缺 boost_context 会让 folly::coro 编译失败
  • 使用 folly::fibers 前,必须在 main() 开头调用 folly::init(&argc, &argv),否则 fiber scheduler 初始化失败,程序可能卡死在第一次 co_await

真正难的不是集成,而是判断哪条路径值得换——多数服务瓶颈在 I/O 或业务逻辑,盲目套 Folly 组件反而增加维护负担。先用 perf 或 vtune 定位 hot function,再看对应组件是否解决那个具体问题。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

318

2023.08.02

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

258

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

209

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1468

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

620

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

550

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

546

2024.04.29

go语言字符串相关教程
go语言字符串相关教程

本专题整合了go语言字符串相关教程,阅读专题下面的文章了解更多详细内容。

165

2025.07.29

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

19

2026.01.20

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Java 教程
Java 教程

共578课时 | 48.5万人学习

国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 1.0万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号