Rust 中 #[thread_local] 的drop方法不被调用
原文链接: https://drmingdrmer.github.io/tips/#/page/rust-thread-local-drop
Rust 中有2种方法声明 thread-local[2] 变量: 使用标准库的宏 thread_local!{}
[3] 或使用 attribute #[thread_local]
[4], 经在databend的好友 winter[5], 提醒, 这里有个不rust的地方, #[thread_local]
按官方说法是被"translates directly to the thread_local
attribute in LLVM", 线程销毁时不会调用它的drop
方法, 但宏声明的thread-local变量没问题:
使用宏 thread_local!{...}
定义, 正常调用了 drop
:
struct Foo(usize);
impl Drop for Foo {
fn drop(&mut self) { println!("dropped"); }
}
thread_local! {
static MACRO_TLS: std::cell::RefCell<Foo> = std::cell::RefCell::new(Foo(0));
}
fn main() {
let _ = std::thread::spawn(|| unsafe {
MACRO_TLS.with(|f| {
println!("foo: {}", f.borrow_mut().0);
});
})
.join();
}
// Output:
// foo: 0
// dropped
使用 attribute #[thread_local]
定义, 没有调用 drop
:
#![feature(thread_local)]
struct Foo(usize);
impl Drop for Foo {
fn drop(&mut self) { println!("dropped"); }
}
#[thread_local]
static mut ATTR_TLS: Foo = Foo(0);
fn main() {
let _ = std::thread::spawn(|| unsafe {
println!("foo: {}", ATTR_TLS.0);
})
.join();
}
// Output:
// foo: 0
引用链接
[1] 原文链接: https://drmingdrmer.github.io/tips/#/page/rust-thread-local-drop
[2]
thread-local: https://en.wikipedia.org/wiki/Thread-local_storage
[3]
thread_local!{}
: https://doc.rust-lang.org/std/macro.thread_local.html
[4]
#[thread_local]
: https://doc.rust-lang.org/beta/unstable-book/language-features/thread-local.html
[5]
winter: https://github.com/zhang2014
相关文章
- 在 Go 里用 CGO?这 7 个问题你要关注!
- 9款优秀的去中心化通讯软件 Matrix 的客户端
- 求职数据分析,项目经验该怎么写
- 在OKR中,我看到了数据驱动业务的未来
- 火山引擎云原生大数据在金融行业的实践
- OpenHarmony富设备移植指南(二)—从postmarketOS获取移植资源
- 《数据成熟度指数》报告:64%的企业领袖认为大多数员工“不懂数据”
- OpenHarmony 小型系统兼容性测试指南
- 肯睿中国(Cloudera):2023年企业数字战略三大趋势预测
- 适用于 Linux 的十大命令行游戏
- GNOME 截图工具的新旧截图方式
- System76 即将推出的 COSMIC 桌面正在酝酿大变化
- 2GB 内存 8GB 存储即可流畅运行,Windows 11 极致精简版系统 Tiny11 发布
- 迎接 ecode:一个即将推出的具有全新图形用户界面框架的现代、轻量级代码编辑器
- loongarch架构介绍(三)—地址翻译
- Go 语言怎么解决编译器错误“err is shadowed during return”?
- 敏捷:可能被开发人员遗忘的部分
- Denodo预测2023年数据管理和分析的未来
- 利用数据推动可持续发展
- 在 Vue3 中实现 React 原生 Hooks(useState、useEffect),深入理解 React Hooks 的