- 值超出范围时, 删除特性用于释放文件或网络连接之类的资源。
- 删除特性用于取消分配Box < T> 指向的堆上的空间。
- drop trait用于实现drop()方法, 该方法采用对自身的可变引用。
struct Example
{
a : i32, }
impl Drop for Example
{
fn drop(&
mut self)
{
println!("Dropping the instance of Example with data : {}", self.a);
}
}
fn main()
{
let a1 = Example{a : 10};
let b1 = Example{a: 20};
println!("Instances of Example type are created");
}
输出
Instances of Example type are created
Dropping the instance of Example with data : 20
Dropping the instance of Example with data : 10
程序说明
- 我们已经在Example类型上实现了Drop trait, 并在Drop trait实现的内部定义了drop()方法。
- 在main()函数内部, 我们创建了Example类型的实例, 在main()函数的末尾, 实例超出了范围。
- 当实例移出范围时, Rust隐式调用drop()方法以删除Example类型的实例。首先, 它将删除b1实例, 然后删除a1实例。
【Rust删除特质trait实例分析】让我们看一个简单的示例, 手动删除该值:
struct Example
{
a : String, }
impl Drop for Example
{
fn drop(&
mut self)
{
println!("Dropping the instance of Example with data : {}", self.a);
}
}
fn main()
{
let a1 = Example{a : String::from("Hello")};
a1.drop();
let b1 = Example{a: String::from("World")};
println!("Instances of Example type are created");
}
输出
文章图片
在上面的示例中, 我们手动调用drop()方法。 Rust编译器会引发错误, 不允许我们显式调用drop()方法。我们没有显式调用drop()方法, 而是调用std :: mem :: drop函数在该值超出作用域之前将其删除。
- std :: mem :: drop函数的语法与Drop特性中定义的drop()函数不同。 std :: mem :: drop函数包含作为参数传递的值, 该值在超出范围之前将被删除。
struct Example
{
a : String, }impl Drop for Example
{
fn drop(&
mut self)
{
println!("Dropping the instance of Example with data : {}", self.a);
}
}fn main()
{
let a1 = Example{a : String::from("Hello")};
drop(a1);
let b1 = Example{a: String::from("World")};
println!("Instances of Example type are created");
}
输出
Dropping the instance of Example with data : Hello
Instances of Example type are created
Dropping the instance of Example with data : World
在上面的示例中, 通过将a1实例作为参数传递给drop(a1)函数来销毁a1实例。
推荐阅读
- Rust Box T用法
- Rust Deref T解析和用法
- Rust可恢复错误处理实例分析
- Rust带有panic!不可恢复的错误
- Rust什么是向量(向量的用法)
- Rust字符串的介绍和用法
- Mac系统下使用Fastboot线刷安卓设备
- 如何查看app包名
- Android Studio升级3.6 Build窗口出现中文乱码问题解决方案