質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Git

Gitはオープンソースの分散バージョン管理システム(DVCS)です。

Q&A

解決済

1回答

404閲覧

git stashについて、

Yaki_yaki11

総合スコア18

Git

Gitはオープンソースの分散バージョン管理システム(DVCS)です。

0グッド

0クリップ

投稿2020/06/10 05:09

gitのstashについて、教えていただきたいです。

状況としては、
チームで開発していて、ローカルリポジトリにリモートの内容を反映させようとpullします。
そこで、自分が修正していたファイルを、別のメンバーがいじってコミットしていたため、pullすると競合してしまいます。

Your local changes to the folloing files would be overwritten by merge.
とエラーが表示されます。

そこで、
git stash save で自分の変更分を退避させて、一旦ソースを最新の状態にしてから、
git stash pop で自分の変更分も適用されています。

退避させてからpullして最新になったソースに、git stash popをするとそこで同じファイルを変更しているのだから、
コンフリクトが発生すると思ったのですが、しませんでした。
ここの理屈があまり分かりません。

ぜひ教えていただきたいです。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

自分の変更とリモートの変更箇所がかぶっていなかったのでしょう

投稿2020/06/10 05:21

編集2020/06/10 05:28
SHOMI

総合スコア4079

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Yaki_yaki11

2020/06/10 05:43

pullした際に発生したエラーは同じファイルをいじっていたから発生しましたけど、 git stash popでは、ソース自体の変更箇所を見ているため、エラーが起きなかったという意味でしょうか。
SHOMI

2020/06/10 05:55

stashも内部的にはコミットしているので変更がかぶっていなければ自動マージされます。
Yaki_yaki11

2020/06/10 08:47

分かりました。ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問