クロージャーでオブジェクトを参照するのは難しいことではありません。一般的に、これらの参照は不変です。単一リンクリストと違って、どこかで突然変異を作成せずにその部分を変更することはできないので、二重連結リストを不可能にする不変性です。これを確認するには
、私は、単独でリンクリストを持っている
a -> b -> c
と私はそれの頭を変更したいと考えます。私はリストの全体を変更して、そうすることができます。ヘッド値の新しい値を作成して、テールを再利用して新しいリストを作成します。
a'-> b -> c
ただし、重複したリストは不可能です。したがって、クロージャーやその他の関数型言語では、このような状況でzipperを使用することがあります。
Clojureで実際に変更可能な参照が必要だとしたらどうでしょうか?さて、何が必要同時実行のセマンティクスに応じて、Clojureのはvars、refs、など
を持っている。また、deftypeで、あなたは可変フィールドを持つオブジェクトを作成することができ、これらの変更可能なフィールドは、他のものへの参照を保持することができます。この同じ目的のために、クロージャで生のJava配列を使用することもできます。
データベースはインメモリデータベースまたはディスクバックアップデータベースになりますか?ディスク上にある場合は、pointer swizzlingの問題は、変更可能な参照を持つよりも扱いにくいと思います。
機能的なデータ構造の問題に戻って、純粋に機能的なセマンティクスを持つBツリーを作成することは可能です。ここでの最初の手がかりは、それが木であり、木は機能的なデータ構造のパンとバターです。第2に、append-onlyの方法で動作するデータベース、例えばcouchDBがあることに注意してください。これは、ある意味で、データベースが独自のログであるという利点があります。このアプローチのコストと利点のアイデアをもっと得るには、watch Slava Akhmechet's presentationが望ましいかもしれません。彼の会社、RethinkDBは、最終的には、IIRCのようなハイブリッドアプローチを採用しました。
私はこの問題を完全には理解していませんが、好奇心から外れています:リンクリストはなぜ他の方法で問題を解決できなかったのですか? – Belun
リンクリストを実装しようとしていませんでした。私がB +ツリーを実装している、つまりノードへの参照を扱っている問題は、リンクされたリストを扱うときに遭遇するものと同じです。 – TriArc