Rust进阶之条件编译
2015-05-14 09:21
441 查看
Rust有一个特殊的属性,#[cfg],允许你一句传递给编译器的标志来编译代码。它有两种形式:
它们还有一些辅助形式:
可以随意嵌套:
如果你正在使用Cargo,怎样打开或关闭这些开关,它们在Cargo.toml文件中的[features]节进行设置。
当你这么做了,Cargo会给rustc传递一个参数:
这些cfg标志将会决定哪个一个被激活,因此,哪个代码被编译。我们看一下这段代码:
如果我们使用cargo build --features "foo"编译,它将会把--cfg feature="foo"标志传递给rustc,并且输出将会有一个foo模块。如果我们使用常规的cargo build,没有额外的标志被传递,将不会有foo模块存在。
如果a被使用cfg设置过属性,则跟#一样。
在编译阶段依据配置设定,这些将会被替换成true或false。
#[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,并且输出将会有一个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!"); }
在编译阶段依据配置设定,这些将会被替换成true或false。
相关文章推荐
- C语言及程序设计进阶例程-10 预处理之条件编译
- rust条件编译
- C# 2.0学习之--条件编译
- 不同OS和不同编译器的条件编译小结
- Makefile中用宏定义进行条件编译
- C语言的条件编译
- Java中的条件编译
- 条件编译debug与可变参数宏
- c语言条件编译
- verilog 条件编译命令`ifdef、`else、`endif 的应用
- Java 条件编译
- C++条件编译#ifdef #else
- c#条件编译
- 条件编译
- 我的Android进阶之旅------>Android编译错误java.util.zip.ZipException: duplicate entry的解决方法
- C语言预处理命令之条件编译(#ifdef,#else,#endif,#if等)
- OpenMP入门(2)条件编译和查看线程数的函数
- C语言-宏条件编译详解
- C语言学习入门 (六) 预处理指令:宏、条件编译、文件包含
- C++ 条件编译