为什么Rust写个链表都那么难?

{dede:adminname/} 2025-06-25 18:15:17 {dede:type} 为什么Rust写个链表都那么难?_西藏自治区那曲市巴青县警量笑额运动箱包合伙企业{/dede:type}

表面上看是因为Rust所有权系统不承认线性逻辑中的指数推理规则(Of course!和Why not?),导致链表这种含有“自指”结构的数据结构无法刻画。

但如果承认指数规则的话,要么回到引用计数垃圾回收的机制,要么手写mfree(Why not?)语句。

但这又回到了老路上,违背了Rust的目标。

但是只要我们提前知道链表的最大长度,那么就能写出来了。

例如:已知链表的最大长度是3,那么我们定义3个类型套一下即可。

问题就出在这里,“链表最大…。

为什么Rust写个链表都那么难?
上一篇 : 为什么程序员喜欢在星巴克写代码?
下一篇 : GoLang不需要Rakefile/Makefile,是如何实现交叉编译的?如在X86上生成MIPS的可执行。

猜你喜欢

手机扫一扫添加微信