[解決済み] Pythonで良い_hash__関数を実装する方法 [重複].
2022-09-05 15:21:13
質問
複数のプロパティを持つクラスを実装する場合(下のおもちゃの例のように)、ハッシュを処理する最良の方法は何ですか?
と推測します。
__eq__
と
__hash__
は一貫しているはずですが、すべてのプロパティを扱える適切なハッシュ関数を実装するにはどうしたらよいでしょうか。
class AClass:
def __init__(self):
self.a = None
self.b = None
def __eq__(self, other):
return other and self.a == other.a and self.b == other.b
def __ne__(self, other):
return not self.__eq__(other)
def __hash__(self):
return hash((self.a, self.b))
私は この質問 でタプルがハッシュ可能であることを読んだので、私は上記の例のようなものが賢明であるかどうか疑問に思っていました。それはそうですか?
どのように解決するのですか?
__hash__
は、等しいオブジェクトに対して同じ値を返すべきです。また、オブジェクトの寿命が尽きるまで変化してはいけません。一般的には、immutableなオブジェクトに対してのみ実装します。
些細な実装としては、単に
return 0
. これは常に正しいのですが、パフォーマンスが悪いです。
あなたの解決策、プロパティのタプルのハッシュを返すことは、良いことです。しかし、比較するすべてのプロパティを
__eq__
で比較するすべてのプロパティをタプルにリストアップする必要はないことに注意してください。あるプロパティが通常、不等間隔のオブジェクトに対して同じ値を持つなら、それを省けばいい。ハッシュの計算を必要以上に高価にしないようにしましょう。
編集:私は一般的にハッシュを混合するためにxorを使用しないことをお勧めします。2 つの異なるプロパティが同じ値を持つ場合、それらは同じハッシュを持つことになり、xor を使用するとこれらは互いに相殺されます。タプルはハッシュを混合するために、より複雑な計算を使用します。
tuplehash
で
tupleobject.c
.
関連
最新
-
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 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】_hash__()の正しい実装方法と良い方法は?)
-
[解決済み] PythonでのAWS Lambdaのインポートモジュールエラー
-
[解決済み] Jupyterノートブックでenv変数を設定する方法
-
[解決済み] Django のテストデータベースをメモリ上だけで動作させるには?
-
[解決済み] Pythonの要素別タプル演算(sumなど
-
[解決済み] タプルのリストを複数のリストに変換するには?
-
[解決済み] データフレームをソートした後にインデックスを更新する
-
[解決済み] Pandasを使って、既存のExcelファイルに新しいシートを保存する方法は?
-
[解決済み] PySparkでデータフレームのカラムをString型からDouble型に変更する方法は?
-
[解決済み] 新しいpip backtrackingの実行時問題の解決