Rust 基础入门 ——所有权 引言 :垃圾自动回收机制的缺陷。

在以往,内存安全几乎都是通过 GC 的方式实现,但是 GC 会引来性能、内存占用以及 Stop the world 等问题,在高性能场景和系统编程上是不可接受的,

我们先介绍一下这些概念都是什么:
内存安全是指程序在运行过程中不会访问未分配的内存或者已释放的内存,从而避免了内存相关的错误,如空指针引用、野指针等。传统上,内存安全通常通过垃圾回收(Garbage Collection,GC)来实现,GC会自动回收不再使用的内存,但是它会带来一些性能、内存占用和停顿等问题。

在高性能场景和系统编程中,这些问题是不可接受的。因此,一些编程语言(如Rust)提供了其他的内存安全机制,如所有权系统和借用检查器。这些机制允许程序员在编写代码时显式地管理内存,从而避免了GC带来的性能和停顿问题。同时,这些机制还可以在编译期间检查出潜在的内存安全问题,提前发现和修复错误。

Stop the world是指在垃圾回收(Garbage Collection,GC)过程中,程序的执行会被暂停(停顿),直到垃圾回收完成。在这个停顿期间,程序无法继续执行,所有的线程都被暂停。这种停顿会导致程序的响应性下降,特别是在需要实时性能或低延迟的场景下是不可接受的。

Stop the world问题是垃圾回收机制的一个固有问题,因为在进行垃圾回收时,需要遍历整个堆内存,找出不再使用的对象并进行回收。在这个过程中,程序的执行必须暂停,以确保垃圾回收器能够正确地访问和修改堆内存。

为了减少Stop the world问题的影响,一些现代的垃圾回收算法采用了增量式垃圾回收或并发垃圾回收的方式。

  • 增量式垃圾回收将垃圾回收过程分为多个阶段,在每个阶段中只回收一部分对象,从而减少了停顿的时间。
  • 并发垃圾回收则允许垃圾回收器在程序执行的同时进行回收操作,从而减少了停顿的频率和时间。

GC(垃圾回收) 导致的性能和内存问题的大小取决于多个因素,包括垃圾回收算法的选择、垃圾回收的频率和停顿时间等。

  1. 性能问题:GC会在程序运行时自动回收不再使用的内存,但这个过程需要消耗一定的计算资源。垃圾回收的频率和停顿时间会对程序的性能产生影响。频繁的垃圾回收会导致程序的执行速度变慢,因为大量的计算资源被用于垃圾回收而无法用于实际的业务逻辑。此外,垃圾回收过程中的停顿时间会导致程序的响应性下降,特别是在需要实时性能或低延迟的场景下。

  2. 内存问题:GC 会自动回收不再使用的内存,但是在回收之前,这些内存仍然被占用。因此,GC 可能会导致程序的内存占用变大。此外,GC的回收过程可能会导致内存碎片化,使得内存的利用效率降低。

可能有这些问题的部分发生场景:

  1. 游戏开发:在游戏开发中,需要保持稳定的帧率和低延迟,以提供流畅的游戏体验。如果GC频繁触发或停顿时间过长,会导致游戏卡顿或掉帧,影响游戏的流畅度和响应性能。

  2. 实时系统:在实时系统中,需要保证任务的实时性能,即任务必须在规定的时间内完成。如果GC的停顿时间过长,可能会导致任务无法按时完成,影响系统的实时性能。

  3. 金融交易系统:在金融交易系统中,需要保证交易的低延迟和高吞吐量。如果GC频繁触发或停顿时间过长,可能会导致交易执行时间延长,影响交易的实时性能和系统的吞吐量。

  4. 大规模数据处理:在处理大规模数据时,GC 的内存占用可能会变得很大,导致系统的内存资源不足。此外,GC的停顿时间可能会影响数据处理的效率和响应性能。


好了我们了解到了GC 存在的一些问题,接下来,我们将了解 rust 是通过怎样的思想来避免它的。

相关推荐
pianmian13 小时前
python数据结构基础(7)
数据结构·算法
好奇龙猫5 小时前
【学习AI-相关路程-mnist手写数字分类-win-硬件:windows-自我学习AI-实验步骤-全连接神经网络(BPnetwork)-操作流程(3) 】
人工智能·算法
sp_fyf_20246 小时前
计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-11-01
人工智能·深度学习·神经网络·算法·机器学习·语言模型·数据挖掘
香菜大丸6 小时前
链表的归并排序
数据结构·算法·链表
jrrz08286 小时前
LeetCode 热题100(七)【链表】(1)
数据结构·c++·算法·leetcode·链表
oliveira-time6 小时前
golang学习2
算法
南宫生7 小时前
贪心算法习题其四【力扣】【算法学习day.21】
学习·算法·leetcode·链表·贪心算法
老猿讲编程8 小时前
用示例来看C2Rust工具的使用和功能介绍
rust
金庆8 小时前
How to set_default() using config-rs crate
rust·config·set_default·valuekind
懒惰才能让科技进步8 小时前
从零学习大模型(十二)-----基于梯度的重要性剪枝(Gradient-based Pruning)
人工智能·深度学习·学习·算法·chatgpt·transformer·剪枝