智能指针内存泄漏 C 的智能指针不就基本解决了野指针问题了吗?为什么还要吹捧rust的内存安全?
C 的智能指针不就基本解决了野指针问题了吗?为什么还要吹捧rust的内存安全?
从编译器阶段开始,rust就消除了内存安全问题,包括单线程和多线程。这是由于编译器级别的rust的复杂所有权机制,这使得任何人都不可能编写不安全的代码。这就是法律体系。
使用C/C,世界上没有一个程序员能够保证代码的绝对内存安全性。虽然C是一个屠龙者,但这个问题也非常重要。也就是说,没有办法保证代码的内存安全和线程安全。
C智能指针,或者在使用过程中出现问题,例如多线程环境中的最新共享uptr,如果程序员忘记执行锁定操作怎么办?这不会发生在信任的情况下。使用arc机制,如果不锁定,就无法访问数据。即使在单线程环境中,您能保证所有程序员都不会传递智能指针实例的引用吗?太多了。C无法在编译时发现这些问题。
铁锈是法治,而不是人治。数据访问冲突,根本无法编译
对于软件工程师来说,如何平衡学习技术的深度和广度?
技术的深度和广度相辅相成,相互促进。
通过增加深度,它可以帮助您通过类比学习,加快您的广度扩展。
例如,分布式系统。如果你了解分布式系统的原理,比如Kafka分区和主从备份。当您学习其他分布式系统(如Hadoop)的原理时,您将更容易理解其体系结构设计。从本质上说,他们有同样的问题要解决。它们也是分布式系统的基本问题。
当您学习到一定的深度时,通过增加广度,也将帮助您更深入地了解技术。或者上面的例子。在您了解了Kafka、Hadoop和etcd之后,您会发现对于同一个问题有不同的解决方案。它们适合不同的场景或有不同的优点和缺点。
以JVM的GC为例,有几种不同的算法。通过比较,可以加深认识,拓展思路。
最后,提高您的系统理解和设计能力。它还可以帮助你建立一个完整的知识体系。
我分享了很多分布式动画视频。特殊演示系统原理。欢迎收看。
智能指针内存泄漏 智能指针什么时候不能用 智能指针循环引用问题
版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。