- 第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 有用 const 关键字定义常量的方法:
const N: i32 = 5;
不像 let 绑定那样,您必须标注常量的类型。
常量活在程序的整个生命周期。更具体地说,在 Rust 语言里面常量没有固定内存地址。这是因为他们会被有效的内联到每个使用地方。引用相同的常数并不一定保证引用同一个内存地址也是因为这个原因。
静态
Rust 在静态条目中提供一种“全局变量”。它们类似于常量,但静态条目不内联使用。这意味着每个值只对应一个实例, 并且在内存中只有一个固定的地址。
这里有一个例子:
static N: i32 = 5;
不像 let 绑定那样,您必须标注一个静态的类型。
静态类型活在程序的整个生命周期,因此任何存储在常量中的引用都有“静态生命周期:
static NAME: &'static str = "Steve";
可变性
你可以用 mut 关键字介绍可变性:
static mut N: i32 = 5;
因为这是可变的,一个线程正在更新 N,而此时另一个正在读入它,这样会导致内存不安全。这样访问和改变一个静态 mut 是不安全的,所以必须在一个unsafe 的块里面完成:
unsafe {
N += 1;
println!("N: {}", N);
}
此外,任何存储在 static 的类型都必须是 Sync。
初始化
常量和静态常量都要求给他们一个值。并且他们可能只被赋予一个值,这个值是一个常数表达式。换句话说,在程序运行时,您不能使用函数调用的结果或任何其他类似的复杂操作。
我应该使用哪个构造?
几乎总是如此,如果你能在两者之间选择,那么就选择常量。人们几乎不怎么希望内存地址与你的常量关联到一起,并且允许对常量进行优化,就像常量的使用范围不仅在本程序块也在下游程序块一样。
常量可以被认为是在 C 语 言中用 # define 定义的:这里会有元数据开销,但没有运行开销。“在 C 语言中,我应该使用 # define 还是 static,“很大程度与这个问题是相同的,“在 Rus t语言中,我是应该使用 const 还是 static”。