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

表面上看是因为Rust所有权系统不承认线性逻辑中的指数推理规则(Of course!和Why not?),导致链表这种含有“自指”结构的数据结构无法刻画。
但如果承认指数规则的话,要么回到引用计数垃圾回收的机制,要么手写mfree(Why not?)语句。
但这又回到了老路上,违背了Rust的目标。
但是只要我们提前知道链表的最大长度,那么就能写出来了。
例如:已知链表的最大长度是3,那么我们定义3个类型套一下即可。
问题就出在这里,“链表最大…。

表面上看是因为Rust所有权系统不承认线性逻辑中的指数推理规则(Of course!和Why not?),导致链表这种含有“自指”结构的数据结构无法刻画。
但如果承认指数规则的话,要么回到引用计数垃圾回收的机制,要么手写mfree(Why not?)语句。
但这又回到了老路上,违背了Rust的目标。
但是只要我们提前知道链表的最大长度,那么就能写出来了。
例如:已知链表的最大长度是3,那么我们定义3个类型套一下即可。
问题就出在这里,“链表最大…。


团队 code review 时,一位同事把 count(*...
1、VSCode(Cursor)VSCode 宇宙第一编辑器...
帮发: 96年 女,在深圳南山工作,职业是程序员,收入20w...
核心有两个: 1 选小size的低智模型 2 用trick的...
不能。 。 刚到朝鲜,我的第一反应居然是:“这地方……也太...
cloudflare 已经重写了,他们认为 NGINX 有一...
发小,重度抑郁,几度自杀未遂,熟人都知道是父母的原因,这里就...
主持人 Paul 问:您认为新款苹果笔记本电脑如何? Lin...
初看标题,联想到此前徐波被广州 GA 上门羁押。 还真以为受...
依我之见,32英寸在大部分时候优于27英寸,除非桌子太小不适...
