検索
ホームページコンピューターのチュートリアルコンピュータ知識Git のコミットは差分、スナップショット、または履歴ですか?

Git 提交是差异、快照还是历史记录?

Git コミットがどのように実装されるかを理解するのは簡単ですが、送信に対する他の人の意見を理解するのは困難です。そこで私はマストドン上の他の人にいくつかの質問をしてみました。

Git の提出についてどう思いますか?

私は非常に非科学的な調査を実施し、人々に Git のコミットについてどう思うか尋ねました。それはスナップショットでしょうか、差分でしょうか、それとも以前のすべてのコミットのリストでしょうか? (もちろん、この 3 つすべてであると考えるのが合理的ですが、人々のメインの

が気になります。 ###消す:###

51%の差
  • 42% スナップショット
  • 4% 以前のすべてのコミットの履歴
  • 3%「その他」
  • 差分とスナップショットの 2 つのオプションの比率が非常に近いことに驚きました。また、
「私の意見では、コミットは diff ですが、実際にはスナップショットとして実装されていると思います」や

「私の意見では、コミットはスナップショットですが、実際には diff として実装されていると思います。」送信が実際にどのように実装されるかについては、後ほど詳しく説明します。

先に進む前に: 「違い」または「スナップショット」とは何を意味しますか?

#########違いはなんですか?

私が話している「違い」はおそらく非常に明白です。違いは、git show COMMIT_ID を実行したときに得られるものです。たとえば、rbspy プロジェクトのタイプミスの修正は次のとおりです: リーリー

GitHub でご覧いただけます: https://github.com/rbspy/rbspy/commit/24ad81d2439f9e63dd91cc1126ca1bb5d3a4da5b

スナップショットとは何ですか?

「スナップショット」とは、「git checkout COMMIT_ID を実行したときに取得されるすべてのファイル」のことです。

Git は通常、送信されたファイルのリストを「ツリー」(「ディレクトリ ツリー」など) として参照します。上記で送信されたすべてのファイルは GitHub で確認できます:

https://github.com/rbspy/rbspy/tree/24ad81d2439f9e63dd91cc1126ca1bb5d3a4da5b (/commit/

ではなく

/tree/

です)

「Git の実装方法」は本当にそれを説明する正しい方法でしょうか?

Git の学習に関して私が最もよく聞くアドバイスは、おそらく「Git が内部的に物事をどのように表現するかを学べば、すべてがより明確になります。」です。私は明らかにこの視点がとても好きです (このブログを時間をかけて読んだことがある方なら、私が が好きであることがお分かりいただけると思います) しかし、Git の学習方法としては、私が期待していたほど成功しませんでした。いつもなら、「なるほど、Git コミットはスナップショットで、親コミットへのポインタがあり、ブランチはコミットへのポインタで、そして…」と興奮気味に説明を始めるところですが、People を試してみました。助けてくれた人は、この説明はあまり役に立たなかった、まだ理解できないと言うでしょう。そこで、他の選択肢を検討してきました。

しかし、最初に内部実装について話しましょう。


Git が内部的にコミットを表す方法 - スナップショット

内部的には、Git はコミットをスナップショット (各ファイルの現在のバージョンの「ツリー」を保存する) として表します。 Git リポジトリにいます。ファイルはどこにありますか?これについては で書きましたが、ここでは内部フォーマットの概要を簡単に説明します。 これは提出表現です: リーリー

そして、このツリー オブジェクトを表示すると、このコミットのリポジトリのルートにあるすべてのファイル/サブディレクトリのリストが表示されます。 リーリー

これは、Git コミットのチェックアウトが常に高速であることを意味します。Git にとって、100 万件前のコミットをチェックアウトするのと同じくらい簡単に、昨日のコミットをチェックアウトできます。コミットは差分としてまったく保存されないため、Git は現在の状態を判断するために 10,000 の差分を再適用する必要はありません。

スナップショットはpackfileを使用して圧縮されます

Git のコミットはスナップショットであると述べましたが、「私の意見では、コミットはスナップショットですが、実装の違いだと思います」という人は
、これも実際に当てはまります。 Git
のコミットは、慣れ親しんだ diff の形式では表現されません (前のコミットとの差分としてディスクに保存されません)。しかし、基本的な直観としては、 10,000## 行 # のファイルが 500 回編集された場合、500 個のファイルを保存する効率は非常に低くなります。

Git には、差分の形式でファイルを保存する方法があります。これは「パックファイル」と呼ばれ、Git はディスク領域を節約するために、データをパックファイルに定期的にガベージ コレクションします。リポジトリを

git clone すると、Git はデータも圧縮します。

ここでは、パックファイルがどのように機能するかを完全に説明するのに十分なスペースがありません (Aditya Mukerjee の「Git パックファイルの解凍」は、パックファイルがどのように機能するかを説明する私のお気に入りの記事です)。ただし、デルタがどのように機能するか、およびデルタが diff とどのように異なるかについての私の理解をここで簡単に要約できます:

    オブジェクトは「元のファイル」および「デルタ」への参照として保存されます
  • デルタは、「バイト 0 ~ 100 を読み取り、次にバイト「hello there」を挿入し、バイト 120 ~ 200 を読み取る」などの一連の命令です。元のファイルから新しいテキストをつなぎ合わせます。したがって、「削除」という概念はなく、コピーして追加するだけです。
  • ミュータンスのレイヤーが少ないと思います: Git が特定のオブジェクトを取得するために通過する必要があるミュータンスのレイヤーが何層あるかを確認する方法はわかりませんが、私の印象では、通常はそれほど多くはありません。たぶん10階未満でしょうか?とはいえ、実際に調べる方法を知りたいです。
  • 元のファイルは前のコミットのものである必要はなく、何でも構いません。もしかしたら、後のコミットからのものかもしれませんか?よくわかりません。
  • 変更を計算するための「正しい」アルゴリズムはありません。Git にはいくつかの近似ヒューリスティックがあるだけです

差分を見ると実際に何か奇妙なことが起こっています

特定のコミットの差分を確認するために

git show SOME_COMMIT を実行すると実際に何が起こるかは、少し直感に反します。私の理解は次のとおりです:

Git はパックファイルを調べ、変更を適用して、このコミットとその親コミットのツリーを再構築します。
  • Git は 2 つのディレクトリ ツリー (現在のコミットのディレクトリ ツリーと親コミットのディレクトリ ツリー) 間の差分比較を実行します。ほとんどすべてのファイルがまったく同じであるため、これは通常高速です。そのため、git はほとんど何もせずに同一ファイルのハッシュを比較するだけで済みます。
  • 最後に Git で違いが表示されます
  • したがって、Git は変更をスナップショットに変換し、差分を計算します。差のようなもので始まり、別の違いのようなもので終わるので、少し奇妙に感じますが、変化の量と差は実際にはまったく異なるため、意味はあります。

    そうは言っても、Git はコミットをスナップショットとして保存し、packfile はディスク領域を節約し、クローン作成を高速化するための実装の詳細にすぎないと思います。実際に Packfile がどのように機能するかを知る必要はありませんでしたが、ディスク容量をあまり消費せずに Git スナップショットがどのようにコミットされるかを理解するのに役立ちます。

    #Git の「間違った」理解: コミットは差分である Git の「エラー」については、次のような理解が一般的だと思います。

    コミットは、前のコミット (および親コミット、作成者、およびメッセージへのポインター) に基づく差分として保存されます。
    • コミットの現在の状態を取得するには、Git は以前のすべてのコミットを最初から再適用する必要があります。
    • この理解はもちろん間違っています (実際には、コミットはスナップショットの形式で保存され、差分はこれらのスナップショットから計算されます)。しかし、これは非常に便利で、私にとっては理にかなっています。マージ コミットについて考えると少し奇妙ですが、これはマージ コミットの最初の親コミットに基づく違いに過ぎないと言えるかもしれません。

    この誤解は時には非常に役立つと思いますが、Git を日常的に使用する上では問題ないようです。私たちが最もよく使うもの (違い) が最も基本的な要素になることがとても気に入っています。私にとっては非常に直感的です。

    私はまた、次のような、Git についての有益だが「間違った」理解についても考えてきました。

      コミット情報は編集できます (実際には編集できません。同一のコミットをコピーして新しい情報を与えるだけです。古いコミットはまだ存在します)
    • コミットは別のベースに移動できます (同様に、コピーされます)
    Git にはさまざまな「間違った」理解があると思いますが、それらは完全に理にかなっていて、主に Git ユーザー インターフェイスでサポートされており、ほとんどの場合問題は発生しません。しかし、変更を元に戻したい場合や何か問題が発生した場合は、混乱する可能性があります。

    コミットを差分として扱うことのいくつかの利点

    Git ではコミットがスナップショットであるとわかっていても、おそらくほとんどの場合、コミットを差分として扱います。理由は次のとおりです。

      ほとんどの場合、私は加えている変更に集中します。コード行を変更するだけの場合、明らかに、コードベース全体の現在の状態ではなく、そのコード行について主に考えています
    • GitHub で Git コミットをクリックするか、
    • git show を使用すると、違いがわかります。これは私が見慣れているものです
    • 私はリベースをよく使いますが、重要なのは差分を再適用することです

    コミットをスナップショットとして扱うことのいくつかの利点

    しかし、私は時々コミットをスナップショットと考えることもあります。理由は次のとおりです。

      Git は、ファイルの移動によって混乱することがよくあります。ファイルを移動して編集すると、Git はそれが移動されたことを認識せず、代わりに
    • として表示されます。 「old.py が削除され、new.py が追加されました」。これは、Git はスナップショットのみを保存するためで、「Move old.py -> new.py」と表示された場合は、
      old.pyとnew.pyの内容は似ているので現時点では推測の域を出ません。
    • こうすることで、
    • git checkout COMMIT_ID が何をしているのかを理解しやすくなります (10,000 のコミットを再適用するという考えはストレスになります)
    • マージされたコミットは実際には何でも構いません (単なる新しいスナップショットです!) ので、私にとってマージ コミットはスナップショットのように見えます。これは、マージ競合を解決するときになぜ恣意的な変更が行われる可能性があるのか​​、また競合を解決するときになぜ注意が必要なのかを理解するのに役立ちました。

    提出に関するその他の理解

    マストドンの返信の一部では次のようなことも言及されています:

      コミットに関する「追加の」アウトオブバンド情報 (電子メール、GitHub プル リクエスト、同僚との会話など)
    • 「違い」を「前の状態、後の状態」と考えてください。
    • そしてもちろん、多くの人は状況に応じて提出物を異なる見方をします
    • コミットについて話すときに人々が使用する、それほど曖昧ではないかもしれない他の言葉:

    「リビジョン」 (スナップショットのように見えます)
    • 「パッチ」 (差分のように見えます)
    • #########それでおしまい!

    私は、人々が Git に対して持っているさまざまな理解を理解するのに苦労しています。特に厄介なのは、「間違った」理解が非常に役立つことが多いにもかかわらず、人々は「間違った」メンタル モデルを警戒することに熱心で、一部の Git インタプリタが立ち上がり、なぜ間違っているのかを彼らに説明してください。 (これらの Git インタプリタは通常、良い意味を持ちますが、それに関係なくマイナスの影響を与える可能性があります) でも、たくさんのことを学びました!コミットについてどのように話すべきかはまだ完全にはわかりませんが、最終的にはわかるでしょう。

    Git コミットについて私と議論してくれた Marco Rogers 氏、Marie Flanagan 氏、そして Mastodon の皆さんに感謝します。

    以上がGit のコミットは差分、スナップショット、または履歴ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

    声明
    この記事は每日运维で複製されています。侵害がある場合は、admin@php.cn までご連絡ください。
    RAID回復とハードドライブ回復の違いRAID回復とハードドライブ回復の違いApr 17, 2025 am 12:50 AM

    データの回復は常に加熱されたトピックです。デバイスからデータを正常に復元するには、データの保存方法を知っておく必要があります。このPHP.CNポストからのRAID回復とハードドライブの回復の違いを学ぶことができます。

    Microsoft WordテキストWindows 10/11を削除しますか?今すぐ修正してください!Microsoft WordテキストWindows 10/11を削除しますか?今すぐ修正してください!Apr 17, 2025 am 12:48 AM

    タイピング中に消えてしまう単語テキストに遭遇しますか?文書からいくつかの手紙や段落さえも消えるかもしれません。何が問題なのですか? PHP.CN Webサイトからのこの投稿では、テキストの問題を自動的に削除するという単語を詳しく見ていきます

    オーバーウォッチ2でLC-208エラーコードを修正する方法は?これがガイドです! - ミニトールオーバーウォッチ2でLC-208エラーコードを修正する方法は?これがガイドです! - ミニトールApr 17, 2025 am 12:47 AM

    Overwatch 2にログインしようとしている場合、LC-208エラーメッセージを受信し、ゲームがゲームサーバーに接続するのを防ぐことができます。 PHP.CNからのこの投稿では、LC-208オーバーウォッチエラーを修正する方法を紹介します。

    Googleドライブはファイルエクスプローラーから消えました - 簡単な承認Googleドライブはファイルエクスプローラーから消えました - 簡単な承認Apr 17, 2025 am 12:46 AM

    通常、File ExplorerからGoogleドライブファイルにすばやくアクセスして編集できます。ただし、「Google DriveがFile Explorerから消えた」という問題に遭遇する場合があります。ここでPHP.CNのこの投稿は、Googleドライブを取得して表示する方法を教えてくれます

    Windows7のウェルカム画面を遅く修正する方法は?ヒントはこちらです!Windows7のウェルカム画面を遅く修正する方法は?ヒントはこちらです!Apr 17, 2025 am 12:45 AM

    なぜ私のコンピュータはウェルカム画面に長い間画面にいるのですか? Windows7のウェルカム画面を遅く修正する方法は?まだPCでWindows 7を実行してこの問題を満たしている場合、あなたは適切な場所にいて、PHP.CNによって複数のソリューションがここに与えられます。

    Windows 11で資格情報マネージャーを開く方法は?あなたのための6つの方法! - ミニトールWindows 11で資格情報マネージャーを開く方法は?あなたのための6つの方法! - ミニトールApr 17, 2025 am 12:44 AM

    組み込みのパスワード管理ツールを使用して、Webおよびアプリのログイン資格情報を管理したいですか? Windows 11で資格管理マネージャーを開くにはどうすればよいですか?この投稿では、PHP.CNがこのユーティリティにアクセスするための複数の方法を収集し、

    Microsoft Defenderで定期的なスキャンを有効/無効にする方法-MinitoolMicrosoft Defenderで定期的なスキャンを有効/無効にする方法-MinitoolApr 17, 2025 am 12:43 AM

    Microsft Defender Antivirusには、Riperic Sc​​anningと呼ばれる機能があります。これは、Windows 11/10デバイスに別のウイルス対策製品をインストールしたときに有効にできます。さて、PHP.CNからのこの投稿は、Wiで定期的なスキャンを有効/無効にする方法を教えています

    Excelハイパーリンクのためのスマートテクニックは、Winに取り組んでいませんExcelハイパーリンクのためのスマートテクニックは、Winに取り組んでいませんApr 17, 2025 am 12:42 AM

    「Excelハイパーリンクが機能しない」という問題に遭遇したことはありますか?あなたはそれに対処する方法を知っていますか? PHP.CNからのこの投稿では、この問題を取り除くためにいくつかの実行可能なソリューションを取得できます。そして、あなたは専門的なデータ回復ツールを知っているでしょう

    See all articles

    ホット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ヘンタイを無料で生成します。

    ホットツール

    SecLists

    SecLists

    SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

    PhpStorm Mac バージョン

    PhpStorm Mac バージョン

    最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

    DVWA

    DVWA

    Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

    Dreamweaver Mac版

    Dreamweaver Mac版

    ビジュアル Web 開発ツール

    ドリームウィーバー CS6

    ドリームウィーバー CS6

    ビジュアル Web 開発ツール