Rust 程序设计(第 2 版)
Jim Blandy, Jason Orendorff, Leonora F. S. Tindall
软件工程师
1469 人已学习
立即订阅
登录后,你可以任选4讲全文学习
推荐试读
换一换
课程目录
已完结/共 41 讲
时长 02:41
时长 06:30
时长 10:04
时长 01:05
时长 50:06
时长 31:35
时长 34:39
时长 29:11
时长 37:15
时长 23:44
时长 44:19
时长 29:54
时长 39:01
时长 01:38
时长 01:15
时长 00:37
Rust 程序设计(第 2 版)
15
15
1.0x
00:00/00:00
登录|注册

第 22 章 不安全代码(1)

确认放弃笔记?
放弃后所记笔记将不保留。
新功能上线,你的历史笔记已初始化为私密笔记,是否一键批量公开?
批量公开的笔记不会为你同步至部落
公开
同步至部落
取消
完成
0/2000
荧光笔
直线
曲线
笔记
复制
AI
  • 深入了解
  • 翻译
    • 英语
    • 中文简体
    • 中文繁体
    • 法语
    • 德语
    • 日语
    • 韩语
    • 俄语
    • 西班牙语
    • 阿拉伯语
  • 解释
  • 总结

Rust语言中的不安全代码特性允许程序员告知Rust:“我选择使用你无法保证安全的特性”,并通过标记块或函数为不安全来获得调用标准库中的unsafe函数、解引用不安全指针以及调用其他语言编写的函数等能力。不安全代码的使用使得Rust可以实现自身许多最基本的特性,如高效地管理缓冲区、与操作系统对话以及提供并发原语。文章还介绍了不安全因素的来源,以及如何使用不安全块来解锁额外的选项,如调用unsafe函数、解引用裸指针、访问union的字段、访问可变的static变量以及访问通过Rust的外部函数接口声明的函数和变量。通过不安全代码特性,程序员可以在遵守额外规则的前提下,实现更多底层的操作,但也需要自行承担遵守规则的责任,以避免未定义行为的发生。文章还通过一个示例展示了如何使用不安全操作实现了一个安全接口,并准备好仅依赖模块自己的代码而不必靠其用户的行为来满足它们的契约。同时,不安全函数的使用也被介绍,强调了标记函数为unsafe会警告其调用者,为避免未定义行为,该函数具有他们必须满足的契约。文章深入探讨了Rust语言中的不安全代码特性,以及如何在遵守额外规则的前提下实现更多底层的操作。文章还指出了不安全代码可能导致的未定义行为,以及如何在使用不安全特性时自行承担责任,同时强调了在可能的情况下创建不需要契约的安全接口。

仅可试看部分内容,如需阅读全部内容,请付费购买文章所属专栏
《Rust 程序设计(第 2 版)》
立即购买
登录 后留言

精选留言

由作者筛选后的优质留言将会公开显示,欢迎踊跃留言。
收起评论
显示
设置
留言
收藏
沉浸
阅读
分享
手机端
快捷键
回顶部