Rust 教程
- 第1节:Rust 介绍
- 第2节:Rust 安装
- 第3节:Rust Hello,world!
- 第4节:Rust Hello,Cargo!
- 第5节:Rust 栈和堆
- 第6节:Rust 测试
- 第7节:Rust 条件编译
- 第8节:Rust 文档
- 第9节:Rust 迭代器
- 第10节:Rust 并发性
- 第11节:Rust 错误处理
- 第12节:Rust 外部函数接口
- 第13节:Rust Borrow 和 AsRef
- 第14节:Rust 发布通道
- 第15节:Rust 变量绑定
- 第16节:Rust 函数
- 第17节:Rust 基本类型
- 第18节:Rust 注释
- 第19节:Rust if
- 第20节:Rust for 循环
- 第21节:Rust while 循环
- 第22节:Rust 所有权
- 第23节:Rust 引用与借用
- 第24节:Rust 生存期
- 第25节:Rust 可变性
- 第26节:Rust 结构体
- 第27节:Rust 枚举
- 第28节:Rust 匹配
- 第29节:Rust 模式
- 第30节:Rust 方法语法
- 第31节:Rust 向量
- 第32节:Rust 字符串
- 第33节:Rust 泛型
- 第34节:Rust 特征
- 第35节:Rust 降
- 第36节:Rust if let
- 第37节:Rust 特征的对象
- 第38节:Rust 闭包
- 第39节:Rust 通用函数调用语法
- 第40节:Rust 箱和模块
- 第41节:Rust “常量”和“静态”
- 第42节:Rust 属性
- 第43节:Rust type 别名
- 第44节:Rust 类型转换
- 第45节:Rust 关联类型
- 第46节:Rust 全类型
- 第47节:Rust 操作符和重载
- 第48节:Rust 'Deref'强制转换
- 第49节:Rust 宏命令
- 第50节:Rust 原始指针
- 第51节:Rust unsafe
Rust 条件编译
条件编译
Rust 有一个特殊属性 #[cfg],它允许你编译基于标志的代码并传递给编译器。它有两种形式:
#[cfg(foo)]
#[cfg(bar = "baz")]
他们也有一些帮助:
#[cfg(any(unix, windows))]
#[cfg(all(unix, target_pointer_width = "32"))]
#[cfg(not(foo))]
这些可以随意嵌套:
#[cfg(any(not(unix), all(target_os="macos", target_arch = "powerpc")))]
至于如何启用或禁用这些开关,如果你使用 Cargo,可以在 Cargo.toml 的 [features] 部分 加以设置:
[features]
# no features by default
default = []
# The “secure-password” feature depends on the bcrypt package.
secure-password = ["bcrypt"]
当你这样做时,Cargo 传递一个标识给 rustc:
--cfg feature="${feature_name}"
这些 cfg 标识的总和将决定哪些得到激活,从而致使哪些代码被编译。让我们看看这段代码:
#[cfg(feature = "foo")]
mod foo {
}
如果我们使用 cargo build --features "foo" 编译代码,它将发送 --cfg feature="foo" 标识给 rustc,且输出中包含 mod foo。如果我们定期地使用 cargo build 编译它,也不传递额外的标识,就不会存在任何 foo 模块。
cfg_attr
你也可以使用 cfg_attr 设置另一个基于 cfg 变量的属性:
#[cfg_attr(a, b)]
如果 a 使用 cfg 属性设定,和使用 #[b] 是相同的。
cfg!
cfg! 语法扩展允许你在你代码中的任何位置使用这些类型标记:
if cfg!(target_os = "macos") || cfg!(target_os = "ios") {
println!("Think Different!");
}
根据配置设置不同,这些在编译时取真或假。