[解決済み] ハッシャブル、イミュータブル
2023-04-04 06:01:33
質問
最近のSOの質問から( リストでインデックスされたpythonの辞書を作成する )から、私はおそらくpythonにおけるハッシュ可能なオブジェクトと不変のオブジェクトの意味について間違った概念を持っていたことに気づきました。
- 実際、hashable は何を意味するのでしょうか?
- hashable と immmutable の関係は?
- ハッシュ可能なmutableオブジェクトやハッシュ不可能なimmutableオブジェクトは存在するのでしょうか?
どのように解決するのですか?
ハッシュ化
とは、ある大量のデータをより小さな量(通常は単一の整数)に反復可能な方法で変換し、定常的にテーブルで検索できるようにするプロセスです (
O(1)
) でテーブルを検索できるようにするプロセスであり、高性能なアルゴリズムやデータ構造にとって重要なものです。
不変性 とは、オブジェクトが作成された後、特にそのオブジェクトのハッシュ値を変更するような重要な方法で変更されないという考え方です。
この 2 つの考え方は、ハッシュ キーとして使用されるオブジェクトは通常、ハッシュ値が変更されないように不変でなければならないので、関連しています。 もし変更が許されるなら、ハッシュテーブルのようなデータ構造におけるそのオブジェクトの位置は変わり、効率のためのハッシュの目的全体が失われることになります。
この考えを本当に理解するには、C/C++のような言語で独自のハッシュテーブルを実装してみるか、Javaの
HashMap
クラスのJava実装を読んでみてください。
関連
-
[解決済み] 文字列リテラルの前にある'b'文字は何を意味するのでしょうか?
-
[解決済み] 最小限の驚き」と「変更可能なデフォルトの引数
-
[解決済み] Pythonでシングルトンを作成する
-
[解決済み] pandasを使った "大量データ "ワークフロー【終了しました
-
[解決済み] 「is" 演算子が整数に対して予期せぬ振る舞いをする。
-
[解決済み] PythonとCpythonの比較
-
[解決済み] 通常のPythonのリストと比較した場合、NumPyの利点は何ですか?
-
[解決済み] SQLAlchemy: セッションの作成と再利用
-
[解決済み] Pythonの要素別タプル演算(sumなど
-
[解決済み] 新しいpip backtrackingの実行時問題の解決
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】Pythonの "hashable "の意味は?
-
[解決済み] Pythonです。未束縛のメソッドを束縛する?
-
[解決済み] 小数点以下1桁を取得する[重複]。
-
[解決済み] 文字列のリストを内容に基づいてフィルタリングする
-
[解決済み] Python Logging でログメッセージが2回表示される件
-
[解決済み] Pandasのデータフレーム内の文字列を'date'データ型に変換するにはどうしたらいいですか?
-
[解決済み] pycharmがタブをスペースに自動変換する
-
[解決済み] Pythonの辞書にあるスレッドセーフについて
-
[解決済み] Django filter queryset __in for *every* item in list
-
[解決済み] Pythonでリストが空かどうかをチェックする方法は?重複