ホームページ バックエンド開発 PHPチュートリアル PHP_PHP チュートリアルのハッシュ アルゴリズム

PHP_PHP チュートリアルのハッシュ アルゴリズム

Jul 13, 2016 pm 05:47 PM
hash php table 協会 物体 属性 配列 はい アルゴリズム

ハッシュ テーブルは PHP の中核です。これは決して誇張ではありません。
PHP の配列、連想配列、オブジェクト プロパティ、関数テーブル、シンボル テーブルなどはすべて HashTable をコンテナとして使用します。
言うまでもなく、PHP の HashTable は競合を解決するためにジッパー メソッドを使用します。今日の私の主な焦点は、PHP のハッシュ アルゴリズムと、アルゴリズム自体によって明らかにされるいくつかのアイデアです。 PHP のハッシュは、最も一般的な DJBX33A (Daniel J. Bernstein、Times 33 with Addition) を使用します。このアルゴリズムは、Apache、Perl、Berkeley DB などの複数のソフトウェア プロジェクトで広く使用されており、現在知られている最良のハッシュ アルゴリズムです。なぜなら、それは非常に高速で、非常によく分類されるからです (衝突が少なく、均等に分散されます
)。 アルゴリズムの核となる考え方は次のとおりです:
1. ハッシュ(i) = ハッシュ(i-1) * 33 + str[i]


  • zend_hash.h には、PHP のこのアルゴリズムがあります:
    1. 静的インライン ulong zend_inline_hash_func(char *arKey, uint nKeyLength)
    2. {
    3. ulong ハッシュ = 5381;
    を登録します 4.
    5. /* ハッシュを 8 回展開したバリアント */
    6. for (; nKeyLength >= 8; nKeyLength -= {
    7. ハッシュ = ((ハッシュ 8. ハッシュ = ((ハッシュ 9. ハッシュ = ((ハッシュ 10. ハッシュ = ((ハッシュ 11. ハッシュ = ((ハッシュ 12. ハッシュ = ((ハッシュ 13. ハッシュ = ((ハッシュ 14. ハッシュ = ((ハッシュ 15. }
    16. スイッチ (nKeyLength) {
    17. ケース 7: ハッシュ = ((ハッシュ 18. ケース 6: ハッシュ = ((ハッシュ 19. ケース 5: ハッシュ = ((ハッシュ ; 20. ケース 4: hash = ((hash ; 21. ケース 3: hash = ((hash ; 22. ケース 2: hash = ((hash ; 23. ケース 1: ハッシュ = ((ハッシュ 25. EMPTY_SWITCH_DEFAULT_CASE()
    26. }
    27. ハッシュを返す;
    28. } Apache と Perl で直接採用されている古典的な Times 33 アルゴリズムとの比較:
    1. Perl 5.005で使用されるハッシュ関数:
    2. # 文字列のハッシュ値を返します: $hash = perlhash("key")
    3. # (hv.h の PERL_HASH マクロによって定義)
    4. サブパールハッシュ
    5. {
    6. $hash = 0;
    7. foreach (分割 //、シフト) {
    8. $hash = $hash*33 + ord($_);
    9. }
    10. return $hash;
    11. } PHP のハッシュ アルゴリズムでは、非常に微妙な違いが見られます。
    まず第一に、最も異なる点は、PHP は 33 による直接乗算を使用せず、次のものを使用することです。 1. ハッシュ もちろん、車に乗るよりも早くなります
    次に、考慮すべき最も重要なことは、Discuz のキャッシュ メカニズムに関する記事を数日前に読みました。その記事の 1 つは、Discuz は投稿の人気に応じて異なるキャッシュ戦略を採用すると述べています。 、投稿の最初のページのみをキャッシュします (投稿を読む人がほとんどいないため)。
    この考え方と同様に、PHP では 8 桁未満の文字インデックスを使用して、効率を向上させています。 さらにインライン変数やレジスタ変数もあり…PHP開発者がハッシュ最適化にも熱心に取り組んでいることがわかります
    最後に、ハッシュの初期値は 5381 に設定されます。Apache のタイムズ アルゴリズムと Perl のハッシュ アルゴリズム (どちらも初期ハッシュが 0 を使用します) と比較して、なぜ 5381 を選択するのか、具体的な理由はわかりません。 5381 のいくつかの機能を発見しました:
    1. 魔法定数 5381:
    2. 1. 奇数
    3. 2. 素数
    4. 3. 不足数
    5. 4. 001/010/100/000/101
    これを読んだ後、この初期値を選択するとより適切な分類ができると信じる理由ができました。
    なぜ Times 33 が Times の他の数字ではなく Times 33 なのかについては、PHP ハッシュ アルゴリズムのコメントにいくつかの説明があります。興味のある学生にとって役立つと幸いです。 1. DJBX33A (ダニエル・J・バーンスタイン、タイムズ33、追加)
    2.
    3. これは、ダニエル J. バーンスタインの人気のある「33 倍」ハッシュ関数です
    4. 数年前に彼が comp.lang.c に投稿したもので、基本的には関数を使用します
    5. 「hash(i) = hash(i-1) * 33 + str[i]」のように、これは最高の 1 つです
    。 6. 文字列の既知のハッシュ関数は両方とも非常に計算されるためです
    。 7. 高速で非常によく配布されます。
    8.
    9. 33 という数字の魔法、つまり、なぜ他の数字よりもうまく機能するのか
    10. 定数は、素数であろうとなかろうと、
    によって適切に説明されたことはありません。 11. 誰でもいいので、実験的にすべてをテストした場合の説明を試みます
    12. 1 から 256 までの乗数 (RSE が今行ったように) は偶数であることを検出します
    13. 残りの128個の奇数は全く使えません
    14. (1 番を除いて) 彼らは多かれ少なかれ全員同じようにうまく働きます
    。 15. すべて許容可能な方法で配布し、この方法でハッシュ テーブルを埋めます
    16. 平均パーセントは約 86% です。 17.
    18. バリアントの Chi^2 値を比較すると、数値 33 は一致しません
    19. 最高の値もありますが、33 とその他の数も同等です
    20. 17、31、63、127、129 などの良い数字には、素晴らしい効果があります
    21. 可能性のある大きなセットの残りの数字に有利
    22. 乗算器: 乗算演算はより高速な乗算演算に置き換えることができます
    23. 1 つのシフトと 1 つの追加のいずれかをベースにした運用
    24. または減算演算。ハッシュ関数は両方を行う必要があるためです
    25. 優れた配布は、_そして_ 計算が非常に高速でなければなりません、それらの少数の
    26. 数字は優先されるべきであり、それがダニエル J.
    の理由のようです 27. バーンスタインもそれを好んでいました
    28.
    29. www.2cto.com -- ラルフ S. エンゲルシャル

    • 著者: ラルーエンス
    • この記事のアドレス: http://www.laruence.com/2009/07/23/994.html


    http://www.bkjia.com/PHPjc/478471.html

    www.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/478471.html技術記事ハッシュ テーブルは PHP の核です。これは決して誇張ではありません。PHP の配列、連想配列、オブジェクト プロパティ、関数テーブル、シンボル テーブルなどはすべて、ジッパーを使用します。
  • このウェブサイトの声明
    この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

    ホットAIツール

    Undresser.AI Undress

    Undresser.AI Undress

    リアルなヌード写真を作成する AI 搭載アプリ

    AI Clothes Remover

    AI Clothes Remover

    写真から衣服を削除するオンライン AI ツール。

    Undress AI Tool

    Undress AI Tool

    脱衣画像を無料で

    Clothoff.io

    Clothoff.io

    AI衣類リムーバー

    AI Hentai Generator

    AI Hentai Generator

    AIヘンタイを無料で生成します。

    ホットツール

    メモ帳++7.3.1

    メモ帳++7.3.1

    使いやすく無料のコードエディター

    SublimeText3 中国語版

    SublimeText3 中国語版

    中国語版、とても使いやすい

    ゼンドスタジオ 13.0.1

    ゼンドスタジオ 13.0.1

    強力な PHP 統合開発環境

    ドリームウィーバー CS6

    ドリームウィーバー CS6

    ビジュアル Web 開発ツール

    SublimeText3 Mac版

    SublimeText3 Mac版

    神レベルのコード編集ソフト(SublimeText3)

    Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Dec 24, 2024 pm 04:42 PM

    PHP 8.4 では、いくつかの新機能、セキュリティの改善、パフォーマンスの改善が行われ、かなりの量の機能の非推奨と削除が行われています。 このガイドでは、Ubuntu、Debian、またはその派生版に PHP 8.4 をインストールする方法、または PHP 8.4 にアップグレードする方法について説明します。

    PHP 開発用に Visual Studio Code (VS Code) をセットアップする方法 PHP 開発用に Visual Studio Code (VS Code) をセットアップする方法 Dec 20, 2024 am 11:31 AM

    Visual Studio Code (VS Code とも呼ばれる) は、すべての主要なオペレーティング システムで利用できる無料のソース コード エディター (統合開発環境 (IDE)) です。 多くのプログラミング言語の拡張機能の大規模なコレクションを備えた VS Code は、

    今まで知らなかったことを後悔している 7 つの PHP 関数 今まで知らなかったことを後悔している 7 つの PHP 関数 Nov 13, 2024 am 09:42 AM

    あなたが経験豊富な PHP 開発者であれば、すでにそこにいて、すでにそれを行っていると感じているかもしれません。あなたは、運用を達成するために、かなりの数のアプリケーションを開発し、数百万行のコードをデバッグし、大量のスクリプトを微調整してきました。

    PHPでHTML/XMLを解析および処理するにはどうすればよいですか? PHPでHTML/XMLを解析および処理するにはどうすればよいですか? Feb 07, 2025 am 11:57 AM

    このチュートリアルでは、PHPを使用してXMLドキュメントを効率的に処理する方法を示しています。 XML(拡張可能なマークアップ言語)は、人間の読みやすさとマシン解析の両方に合わせて設計された多用途のテキストベースのマークアップ言語です。一般的にデータストレージに使用されます

    JSON Web Tokens(JWT)とPHP APIでのユースケースを説明してください。 JSON Web Tokens(JWT)とPHP APIでのユースケースを説明してください。 Apr 05, 2025 am 12:04 AM

    JWTは、JSONに基づくオープン標準であり、主にアイデンティティ認証と情報交換のために、当事者間で情報を安全に送信するために使用されます。 1。JWTは、ヘッダー、ペイロード、署名の3つの部分で構成されています。 2。JWTの実用的な原則には、JWTの生成、JWTの検証、ペイロードの解析という3つのステップが含まれます。 3. PHPでの認証にJWTを使用する場合、JWTを生成および検証でき、ユーザーの役割と許可情報を高度な使用に含めることができます。 4.一般的なエラーには、署名検証障害、トークンの有効期限、およびペイロードが大きくなります。デバッグスキルには、デバッグツールの使用とロギングが含まれます。 5.パフォーマンスの最適化とベストプラクティスには、適切な署名アルゴリズムの使用、有効期間を合理的に設定することが含まれます。

    母音を文字列にカウントするPHPプログラム 母音を文字列にカウントするPHPプログラム Feb 07, 2025 pm 12:12 PM

    文字列は、文字、数字、シンボルを含む一連の文字です。このチュートリアルでは、さまざまな方法を使用してPHPの特定の文字列内の母音の数を計算する方法を学びます。英語の母音は、a、e、i、o、u、そしてそれらは大文字または小文字である可能性があります。 母音とは何ですか? 母音は、特定の発音を表すアルファベットのある文字です。大文字と小文字など、英語には5つの母音があります。 a、e、i、o、u 例1 入力:string = "tutorialspoint" 出力:6 説明する 文字列「TutorialSpoint」の母音は、u、o、i、a、o、iです。合計で6元があります

    PHPでの後期静的結合を説明します(静的::)。 PHPでの後期静的結合を説明します(静的::)。 Apr 03, 2025 am 12:04 AM

    静的結合(静的::) PHPで後期静的結合(LSB)を実装し、クラスを定義するのではなく、静的コンテキストで呼び出しクラスを参照できるようにします。 1)解析プロセスは実行時に実行されます。2)継承関係のコールクラスを検索します。3)パフォーマンスオーバーヘッドをもたらす可能性があります。

    PHPマジックメソッド(__construct、__destruct、__call、__get、__setなど)とは何ですか? PHPマジックメソッド(__construct、__destruct、__call、__get、__setなど)とは何ですか? Apr 03, 2025 am 12:03 AM

    PHPの魔法の方法は何ですか? PHPの魔法の方法には次のものが含まれます。1。\ _ \ _コンストラクト、オブジェクトの初期化に使用されます。 2。\ _ \ _リソースのクリーンアップに使用される破壊。 3。\ _ \ _呼び出し、存在しないメソッド呼び出しを処理します。 4。\ _ \ _ get、dynamic属性アクセスを実装します。 5。\ _ \ _セット、動的属性設定を実装します。これらの方法は、特定の状況で自動的に呼び出され、コードの柔軟性と効率を向上させます。

    See all articles