40个版本
| 0.3.6 | 2024年6月12日 |
|---|---|
| 0.3.5 | 2024年2月29日 |
| 0.3.4 | 2023年6月29日 |
| 0.3.3 | 2022年6月17日 |
| 0.2.8 | 2020年3月21日 |
#39 in 内存管理
373,696 每月下载量
在 5 crates 中使用
3.5MB
4.5K SLoC
snmalloc-rs
注意:MinGW构建已损坏,可能在未来无法修复。请参阅上游的此PR。
snmalloc-rs 为 microsoft/snmalloc 提供了一个包装器,使其可以作为Rust的全局分配器。snmalloc是一个研究分配器。其关键设计特性包括
- 由分配它的同一线程释放的内存不需要任何同步操作。
- 在最初分配它的不同线程中释放内存,不需要任何锁,而是使用一种新颖的消息传递方案将内存返回给原始分配器,在那里它被回收。
- 分配器使用大范围的页面来减少所需的元数据量。
一些旧的基准测试结果可在snmalloc 论文 中找到。一些最新的基准测试结果列在 bench_suite 中。此crate中定义了三个特性
debug:在snmalloc中启用Debug模式。(自0.3.0以来已删除)1mib:使用1mib块配置。从0.2.17开始,这被设置为默认功能(自0.3.0以来已删除)16mib:使用16mib块配置。(自 0.3.0 版本以来已删除)cache-friendly:使分配器更符合缓存友好性(在构建库时将CACHE_FRIENDLY_OFFSET设置为64)。native-cpu:针对主机机的本地 CPU 优化snmalloc。(这不是默认行为,自0.2.14以来)qemu:解决 QEMU 环境中的madvise问题(自 0.3.0 版本以来已删除)stats:启用统计信息local_dynamic_tls:解决无法在静态 TLS 块中分配内存的问题build_cc:使用 cc crate 而不是 cmake 作为构建器(更具有平台无关性)(自 0.3.0 版本以来已删除)usecxx20:如果可用,则启用 C++20 标准usecxx17:使用 C++17 标准check:启用额外的检查以提高安全性,请参阅上游 安全文档。请注意,Rust 中未启用memcpy保护。win8compat:提高旧 Windows 平台的兼容性(移除VirtualAlloc2和其他新 API 的使用)lto:与 InterProceduralOptimization/LinkTimeOptimization 链接notls:启用动态加载,因此禁用 TLS。stats:启用分配统计信息。
要编译 crate,您需要选择 1mib 或 16mib 以确定块配置
要使用 snmalloc-rs,请将其作为依赖项添加
# Cargo.toml
[dependencies]
snmalloc-rs = "0.3.4"
要将 SnMalloc 设置为全局分配器,请将其添加到您的项目中
#[global_allocator]
static ALLOC: snmalloc_rs::SnMalloc = snmalloc_rs::SnMalloc;
对于 MinGW 用户
mingw 版本仅在 nightly 分支和 MSYS 环境下进行测试。我们使用动态链接方法。因此,请确保以下库位于您的 PATH 中
winpthreadatomicstdc++gcc_s
注意:自版本 0.2.12 以来,我们不再需要您为 mingw 目标提供额外的环境变量。
对于 Android 跨平台编译
ANDROID_NDK必须作为环境变量提供ANDROID_PLATFORM可以作为可选环境变量传递ANDROID_ABI由 CMake 自动检测- 特性
android-lld可以用来将snmalloc的链接器设置为lld 特性(android-shared-std可以用来将snmalloc的 STL 库设置为c++_shared(它默认使用c++_static)libstdc++已不再是依赖项)
变更日志
0.3.4
- 跟踪上游到版本 0.6.2。
0.3.3
- 跟踪上游以修复 Linux PAL 错误。
0.3.2
- 跟踪上游以启用旧 Linux 变体。
0.3.1
- 修复了
build_cc功能(在 0.3.0 版本中已损坏)。 - 修复了
native-cpu功能(在 0.3.0 版本中已损坏)。
0.3.0
- 发布以支持 snmalloc 0.6.0。
0.3.0-beta.1
- beta 发布以支持 snmalloc
20.6.0