>  기사  >  웹 프론트엔드  >  Git을 정말 아시나요?

Git을 정말 아시나요?

DDD
DDD원래의
2024-09-25 06:29:31242검색

Do you really know Git?

이 블로그의 이미지는 Scott Chacon, Ben Straub의 "Pro Git"에서 가져온 것입니다

이 블로그에서는 프로그래밍에 사용하는 Git의 일상적인 기능에 대한 모든 종류의 유용한 정보를 읽을 수 있습니다!

개발자가 도구를 맹목적으로 사용하고 내부적으로 어떻게 작동하는지 모르는 것은 쉽습니다. 이러한 추상화는 더 나은 것이지만, 작동 방식을 아는 것이 때로는 노련한 프로그래머와 아마추어 프로그래머 사이의 차이를 만드는 것일 수 있습니다.

몇 가지 멋진 사실을 알아보겠습니다!


1 - 단기 상태

Git을 꽤 오래 사용했다면 git status에 대해 알아두셔야 합니다. 그러나 더 읽기 쉽고 최소한의 상태 출력을 얻을 수 있는 옵션이 있다는 것을 알고 계셨습니까?

짧은 상태 플래그 -s를 사용하면 더 간결한 형식을 얻을 수 있습니다.

$ git status -s
 M README
MM Rakefile
A  lib/git.rb
M  lib/simplegit.rb
?? LICENSE.txt

출력 왼쪽 섹션에 2개의 열이 있는 것을 볼 수 있습니다. 왼쪽 열은 스테이징 영역의 상태를 나타내고, 오른쪽 열은 작업 트리의 상태를 나타냅니다. 작업 순서도 시간순으로 왼쪽에서 오른쪽으로 표시됩니다.

위 출력을 해석해 보겠습니다.

  • "M" - 수정되었으나 연출되지 않음
  • "MM" - 무대에 올렸다가 다시 수정했습니다. 따라서 다음 커밋에는 추가 단계가 필요합니다.
  • "A " - 새 파일이 생성되어 준비되었습니다
  • 'M' - 무대
  • "??" - 새 파일이 생성되었지만 준비되지 않았습니다(추적되지 않음)

2 - 대기 장소 건너뛰기

추적 파일을 스테이징하고 하나의 명령으로 모두 커밋하려면 어떻게 해야 합니까?

git commit -a -m "message"를 사용하면 됩니다.

추적되지 않은 파일(새로 생성된 파일)은 불행하게도 이 마법의 명령으로 스테이징되지 않습니다.


3 - 커밋 기록 보기

git log를 사용하여 저장소에서 수행된 커밋을 시간 역순으로 나열합니다(가장 최근 커밋이 먼저 표시됨).

출력을 사용자 정의할 수 있는 다양한 옵션이 있습니다. 몇 가지 유용한 기능을 살펴보겠습니다.

  • -{number}는 표시되는 로그 항목 수를 제한합니다(예: git log -2는 마지막 두 항목을 표시합니다)
  • --stat은 각 커밋에 대한 파일 수 또는 삽입/삭제 수와 같은 축약된 통계를 표시합니다
  • --pretty=oneline 각 커밋을 한 줄에 인쇄합니다
  • --graph는 브랜치 및 병합 기록을 보여주는 ASCII 그래프를 추가합니다

4 - Git 복원을 사용하여 작업 취소

파일을 언스테이징하려면 git Reset HEAD를 사용하세요. 수정된 파일을 수정 취소하려면 git checkout --{file}을 사용하세요.

이제 이 두 가지를 모두 수행할 수 있는 더 쉬운 방법이 있습니다! Git 버전 2.23.0에는 파일 스테이지 해제 및 수정 취소를 모두 수행하는 2-in-1 기능을 제공하는 git Restore가 도입되었습니다.

  • git Restore {file} - 수정된 파일 수정 취소
  • git Restore --staged {file} - 준비된 파일을 언스테이징합니다

5 - 힘내 가져오기 대 힘내 풀

아마도 프로그래머로서 git pull을 한 번 이상 사용해 보셨을 것입니다. 또한 git fetch에 대해 들어봤을 가능성이 높지만 실제로 사용할 필요는 없었습니다. 자, 이것이 실제로 무엇을 하는지, 그리고 git pull과 어떻게 다른지 이야기해 보겠습니다.

가져오기는 끌어오기 내에서 발생하는 작업의 첫 번째 단계에 불과하다고 생각하면 됩니다.

Pull에서는 원격 저장소의 모든 데이터를 다운로드하여 로컬 저장소로 전송합니다. 이것이 바로 가져오기가 하는 일입니다.

이 시점에서 로컬 저장소에 데이터가 있지만 최신 변경 사항을 적용할 수 있도록 작업 디렉터리와 병합하지 않았습니다. 풀의 다음 단계는 최신 변경 사항이 작업 디렉터리에 있도록 브랜치와 병합하는 것입니다.

따라서 풀은 가져오기와 병합을 동시에 수행하지만 가져오기는 첫 번째 단계만 수행합니다.


6 - Git 별칭

git 명령을 사용자 정의할 수 있는 방법이 있다고 말하면 어떨까요? git config를 통해 가능합니다!

다음과 같이 자주 사용하는 명령에 별칭을 설정할 수 있습니다.

$ git config --global alias.co checkout
$ git config --global alias.br branch
$ git config --global alias.ci commit
$ git config --global alias.st status

이제 git commit을 입력하는 대신 git ci를 입력하면 됩니다.

특정 작업을 보다 직관적으로 만드는 데 도움이 되는 명령에 특히 유용합니다.

$ git config --global alias.unstage 'reset HEAD --'
# the double dash serves as an option separator. 
# It tells Git to treat anything after it as a filename

위 명령은 다음 명령을 동일하게 만듭니다.

  • git unstage fileA
  • git reset HEAD -- fileA

It's also common to add a last command to see your most recent commit:

$ git config --global alias.last 'log -1 HEAD'

That's all for this blog! I hope you learned a few neat tricks for your next project with Git that will improve the quality of your workflow. Thanks for reading!

위 내용은 Git을 정말 아시나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.