这可能是矛盾的,但是如何在函数式编程风格中更新数据实体呢?从我读过的所有内容来看,函数式编程使用转换来返回不可变实体的输出.我唯一能想到的就是完全取代原始实体,但这似乎与经典的更新方法几乎相同.
您是在谈论磁盘数据库实体还是内存中的数据结构.
对于后者,函数式语言使用持久性数据结构,这些数据结构的实现使得新版本和旧版本在更新后都可用,但它们共享公共部分(因此它是有效的).所以你似乎正在返回一个全新的数据结构,但事实上,它与它正在修改的实现共享其大部分实现.
在clojure源代码中可以看到一些非常好的实现(用Java编写) - 我在博客上分开了两个
http://www.loufranco.com/blog/files/20-Days-of-Clojure-Day-7.html
http://www.loufranco.com/blog/files/20-Days-of-Clojure-Day-8.html