'git stash'의 임시 저장 작업에 대한 자세한 설명
이 명령이 필요한 이유
이 명령을 알았을 때 그리고 사용해 본 후에는 이 명령이 정말 사용하기 쉽기 때문에 너무 마음에 들었습니다.
이 명령을 사용할 때의 시나리오를 말씀드리겠습니다.
이때 저는 feature_666 브랜치에 있었고, feature 666 모듈을 구현하는 데 매우 집중하고 날아다니는 키보드처럼 코드를 작성하고 있었습니다. ~~
그렇다면 고객님께 버그가 보고되었습니다. 매우 심각한 문제이므로 즉시 해결해야 합니다. ! !
그래서 새 브랜치가 작동하는지 확인하려면 릴리즈 브랜치로 가야 하는데, 666 기능이 아직 완성되지 않았다면 어떻게 해야 할까요?
이때 객관식 질문에 직면했습니다:
A: 제출 후 전환하고, feature_666 브랜치에 코드를 저장했는데 의미 없는 커밋이 생성되었습니다.
B: 제출하지 않고 바로 전환했지만, 이 옵션을 선택하는 사람은 아무도 없습니다.
선택이 어렵지 않으신가요? 이때, C옵션도 있다는 점 잊지 마세요!
C: git stash를 사용하여 현재 수정 사항(커밋되지 않은 코드)을 캐시에 저장하고 분기를 전환하여 버그를 수정한 다음 돌아와서 git stash pop을 통해 제거합니다.
1. 임시 작업
#查看当前状态 git status #如果有修改,添加修改文件 git add . #暂存操作 git stash save '本次暂存的标识名字'
2. 현재 임시 기록 보기
#查看记录 git stash list
수정 사항은 어디에 저장되나요?
프로젝트에 git init을 사용할 때 추가 버전 제어를 수행하면 프로젝트 경로에 .git 숨겨진 폴더가 생성됩니다. .git은 모든 버전 관리 정보를 저장합니다.
.git/refs/stash는 마지막 stash에 해당하는 노드 포인터를 저장합니다
마찬가지로 .git/log/refs/stash
에서 모든 stash 레코드 정보를 볼 수 있습니다. 여러 stash 저장 상황
ok, 파일을 수정한 다음 git stash를 다시 사용해 보겠습니다. 이때 두 가지 임시 변경 사항이 있는데 어떻게 확인합니까?
git stash list //스테이징 영역의 모든 임시 수정 기록 보기
커밋하지 않고 git stash를 두 번 실행하면 두 stash의 구체적인 수정 사항을 정확하게 구분할 수 없습니다. show 위대한 Git은 전혀 똑똑하지 않습니다. 어떻게 그럴 수 있습니까! .
따라서 이 경우 다음과 같이 숨김 저장 수정에 이름을 지정하는 것이 매우 중요합니다.
git stash save <message>
3. 임시 작업을 복원합니다.
'pop 명령을 사용하여 복원 후 복원합니다. 임시 저장 영역은 현재 기록을 삭제합니다'
#恢复指定的暂存工作, 暂存记录保存在list内,需要通过list索引index取出恢复 git stash pop stash@{index}
'복원 후 임시 저장 영역은 현재 기록을 유지합니다'
#恢复指定的暂存工作, 暂存记录保存在list内,需要通过list索引index取出恢复 git stash apply stash@{index}
4. 임시 저장 영역을 삭제합니다
#删除某个暂存, 暂存记录保存在list内,需要通过list索引index取出恢复 git stash drop stash@{index} #删除全部暂存 git stash clear
권장 튜토리얼: " Git Tutorial》
위 내용은 'git stash'의 임시 저장 작업에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











GIT 코드를 업데이트하는 단계 : 코드 확인 : git 클론 https://github.com/username/repo.git 최신 변경 사항 가져 오기 : Git Fetch Merge 변경 사항 : GIT 병합 원산지/마스터 푸시 변경 (옵션) : Git Push Origin Master

해결 : GIT 다운로드 속도가 느리면 다음 단계를 수행 할 수 있습니다. 네트워크 연결을 확인하고 연결 방법을 전환하십시오. GIT 구성 최적화 : 포스트 버퍼 크기를 늘리고 (GIT 구성-글로벌 http.postBuffer 524288000) 저속 제한 (git config --global http.lowspeedlimit 1000)을 줄입니다. git 프록시 (예 : git-proxy 또는 git-lfs-proxy)를 사용하십시오. 다른 git 클라이언트 (예 : Sourcetree 또는 Github 데스크탑)를 사용해보십시오. 화재 보호를 확인하십시오

Git Commit은 프로젝트의 현재 상태에 대한 스냅 샷을 저장하기 위해 파일 변경을 GIT 저장소에 기록하는 명령입니다. 사용 방법은 다음과 같습니다. 임시 저장 영역에 변경 사항 추가 제출 메시지를 저장하고 종료하기 위해 간결하고 유익한 제출 메시지를 작성하여 제출을 완료하기 위해 제출물을 완료하십시오. 제출자에 서명을 추가하여 제출 내용을보기 위해 GIT 로그를 사용하십시오.

GIT를 통해 로컬로 프로젝트를 다운로드하려면 다음 단계를 따르십시오. GIT를 설치하십시오. 프로젝트 디렉토리로 이동하십시오. 다음 명령을 사용하여 원격 저장소 클로닝 : git 클론 https://github.com/username/repository-name.git

git 저장소를 삭제하려면 다음 단계를 따르십시오. 삭제하려는 저장소를 확인하십시오. 로컬 리포지토리 삭제 : rm -rf 명령을 사용하여 폴더를 삭제하십시오. 원격으로 창고 삭제 : 창고 설정으로 이동하고 "창고 삭제"옵션을 찾은 후 작동을 확인하십시오.

GIT 코드 병합 프로세스 : 충돌을 피하기 위해 최신 변경 사항을 가져옵니다. 병합하려는 지점으로 전환하십시오. 병합을 시작하고 병합을 지정합니다. 병합 충돌을 해결하십시오 (있는 경우). 커밋 메시지를 제공하여 병합을 준비하고 커밋합니다.

전자 상거래 웹 사이트를 개발할 때 어려운 문제가 발생했습니다. 대량의 제품 데이터에서 효율적인 검색 기능을 달성하는 방법은 무엇입니까? 기존 데이터베이스 검색은 비효율적이며 사용자 경험이 좋지 않습니다. 일부 연구 후, 나는 검색 엔진 타입을 발견하고 공식 PHP 클라이언트 Typeense/Typeense-PHP를 통해이 문제를 해결하여 검색 성능을 크게 향상 시켰습니다.

git에 빈 폴더를 제출하려면 다음 단계를 따르십시오. 1. 빈 폴더를 만듭니다. 2. 스테이징 영역에 폴더를 추가하십시오. 3. 변경 사항을 제출하고 커밋 메시지를 입력하십시오. 4. (선택 사항) 변경 사항을 원격 저장소로 밀어 넣습니다. 참고 : 빈 폴더의 이름은 시작할 수 없습니다. 폴더가 이미 존재하는 경우 git add -force를 사용하여 추가해야합니다.
