올바른 코드 제출은 혼란을 방지하고 향후 시간을 절약 할 수 있습니다. 제출물은 많은 파일에 영향을 미치고 여러 기능을 추가하는 대신 한 번에 하나의 특정 문제 만 처리하는 원자력이어야합니다.
좋은 제출은 명확하고 통찰력 있고 원자력이어야합니다. 커밋 구조에는 유형 또는 구성 요소, 명확한 주제 및 선택적 신체 텍스트가 포함되어 있어야 더 많은 컨텍스트 또는 세부 사항을 제공해야합니다.
키워드 및 질문 ID 번호를 사용하여 제출 정보에서 문제를 처리해야합니다. 이는 프로젝트의 작업, 개선 및 오류 추적을 용이하게합니다.
팀의 규모에 관계없이 올바른 코드 제출은 우수한 프로젝트 관리에 중요합니다. 코드 기반의 무결성을 유지하고 다른 개발자가 코드를 이해하고 처리 할 수 있습니다.
- 왜 귀찮게합니까?
이미 GitHub에 프로젝트를 저장 한 경우 파일이 안전하다고 생각할 수 있으며 코드를 업데이트해야 할 때마다 변경 사항을 추출 할 수 있습니다. 이 모든 것이 사실 일 수 있습니다. 그러나 더 많은 노력을 기울여서 어떤 잠재적 문제를 피할 수 있는지, 그리고 당신이 그렇게하면 어떤 추가 혜택을 얻을 수 있는지 살펴 보겠습니다. -
팀워크 또는 개인 작업에서 단일 전용 작업을 피해야합니다
-
위의 이유는 일반적으로 혼자 일하는 데 익숙한 개발자들로부터 나옵니다. 그러나 그들이 다른 사람들과 코드를 공유해야 할 때, 일이 지저분 해지고 많은 설명이 필요합니다. 우리의 직업은 단순한 코드를 작성하는 것 이상입니다. 또한 어느 정도의 조직과 방법론이 필요한 사물을 관리해야합니다. 팀워크는 조직이 열악한 문제로 인한 문제를 폭로 할 가능성이 높지만 혼자 일할 때에도 더 나은 접근 방식의 혜택을 누릴 수 있습니다.
원자 제출 및 부풀어있는 제출 -
우리는 모두 작은 변화를 취소해야하며, 수십 개의 파일을 변경하고 여러 기능을 추가 한 큰 커밋에서 검색하는 것을 찾기 위해서만 있습니다. 변경이 특정 문제 만 처리하는 단일 커밋에 있으면 롤백이 훨씬 쉬워집니다.
혼란스럽고 부풀어 오른 길
이 예에서는 많은 파일이 영향을 받는지 확인할 수 있습니다. 또한 "새로운 구성 요소"정보는 어떤 구성 요소, 이러한 구성 요소의 기능 및 함수가 새롭거나 리팩토링되는지 여부와 같은 많은 정보를 알려주지 않습니다. 또한 기존 오류가 해결 되었습니까? 이 정보는 무언가를 변경하거나 복원해야 할 때 매우 중요합니다. 우리는 건초 더미에서 핀을 찾으려고 노력하고 코드 기반을보고 귀중한 시간 디버깅을 소비 할 수 있습니다.
원자 길
이제 우리는 커밋에 무슨 일이 있었는지에 대한 더 나은 아이디어를 얻기 시작했습니다.
트릭은
우리는 워크 플로의 일부로 반자동으로 변화를 커밋 할 수 있다는 것입니다. 즉, 매우 구체적인 작업 (특정 기능 구현, 오류 수정, 알고리즘 최적화), 테스트를 수행 (필요한 경우 단위 테스트 작성), 메모리가 신선한 경우 설명을 추가 한 다음 제출하는 Work Block <code>git add *
git commit -m "new components"</code>
를 수행하십시오. 지금. 이 과정을 반복하십시오.
좋은 제출 구조
이 규칙은 석재로 설정되어 있지 않지만 좋은 제출물이 어떻게 보일지 평가하는 데 도움이 될 수 있습니다.
Clearness : 변경 사항을 제출하기 위해 수행 한 작업에 대해서는 의심의 여지가 없습니다.
<:> 통찰력 : 코드의 기능을 명확하게 설명하고, 필요한 경우 링크 또는 추가 정보를 제공하며, 오류 또는 처리중인 문제를 표시하십시오.
원자 : 한 번에 한 가지만 처리하십시오 ( "작업 블록"을 고려하십시오.
템플릿을 살펴보고 분해합시다 :
유형, 구성 요소 또는 서브 시스템
이것은 함께 결합 할 수있는 소프트웨어 프로젝트 기능 세트입니다. 예를 들어, angularjs의 소위 유형 또는 srummvm의 소위 서브 시스템.
(필수) 주제
주제는 모든 사람이 한 눈에 볼 수 있도록 제출물에 의해 수행 된 작업에 대한 간단하고 간단한 설명입니다.
주제 형식의 관점에서, 나는 보통 다음과 같은 간단한 지침을 따릅니다.
명령 문장을 사용하십시오 ( "변경"대신 "변경")
첫 번째 문자 를 대문자로하지 마십시오
끝에 기간을 추가하지 마십시오 (.)
옵션이있는 경우 "(…)"add
(선택 사항) 텍스트 -
때때로 우리는 영구 버그를 고치거나 알고리즘을 크래킹 할 때와 같은 컨텍스트를 제공하기 위해 제목 줄에 적합한 것보다 더 많은 세부 사항을 제공해야합니다. -
이 경우, 두 번의 새로운 라인 문자를 입력하여 (주제가 제목으로 사용되도록) 필요한 정보를 입력 할 수 있습니다.
- 문제를 다루는 것을 잊지 마십시오!
마지막으로, 문제를 다루는 또 다른 문제가 있습니다 (pun!). 괜찮은 대규모 및 중간 소프트웨어 개발 프로젝트는 문제 추적기를 사용하여 Atlassian Jira, Bugzilla, Github의 문제 추적기 등이든 작업, 개선 및 오류를 추적해야합니다.
문제 관리
<code>git add ui/login.html static/js/front-end.js
git commit -m "validate input fields for login"</code>
모르는 경우 대부분의 시스템은 제출 정보에서 직접 문제를 관리 할 수 있습니다!
당신은 할 수 있습니다 :
문제를 닫고/해결하십시오
문제가 전에 닫히면 문제를 다시 열어
함수가 나중에 연기되면 보유 문제
이 키워드와 질문의 ID 번호를 사용하십시오.
또한 상태를 수정하고 싶지 않더라도 " #12"와 같은 상태를 수정하고 싶지 않더라도 컨텍스트를 제공하는 방법으로 질문을 인용 할 수 있습니다.
이 모든 참조는 트래커의 문제를 엽니다면 누구나 볼 수 있으므로 주어진 작업 또는 오류의 진행 상황을 쉽게 추적 할 수 있습니다.
요약
당신은 항상 제대로하지 않을 것입니다 (나 자신이 아닙니다!). 일이 지저분해질 수 있으며 때로는 자신이나 팀을 위해 설정 한 규칙을 따르지 않아도됩니다. 프로세스의 일부입니다. 그러나 당신은 단순히 워크 플로에 대한 업그레이드를 수행함으로써 당신과 당신의 팀을 장기적으로 정리하고 시간을 절약 할 수 있다는 것을 알고 있습니다.
나는 또한 경험을 통해 프로젝트가 10 명의 개발자를 포함하고 여전히 당신에 의해 전적으로 처리되어 있다는 것을 알게되므로 거의 불가능합니다. 요컨대, 올바른 방식으로 코드 변경을 제출하는 것 - 이것은 우수한 프로젝트 관리의 핵심 부분입니다.
추가 읽기
git 역사와 이야기를 들려주십시오. Futurelearn의 Seb Jabocs의 흥미로운 기사.
Angular의 제출 정보 안내서. Angular를 사용하지 않더라도 도움이되는 독서입니다.
freebsd 제출자 가이드. 하나가 있다면 주제에 대한 심층적 인 안내서가 있습니다.
코드베이스에서 파일을 올바르게 구성하고 혼란을 피하는 방법. 우리는 크고 작은 프로젝트를 위해 문서를 구성하는 방법을 설명하여 따라하기 쉬운 모범 사례를 제공합니다.
빠른 시작 git. 이 간결한 가이드는 초보자가 주말에 Git을 신속하게 마스터하는 데 도움이되도록 설계되었습니다.
<.> 전문적인 git. Wiley의 책은 한 걸음 더 나아가 개발자들에게 심층적 인 연구를 제공하여 GIT 마스터가되기 위해 필요한 심층적 인 연구를 제공합니다.
- faqs (faq)
-
코드 기반과 소스 코드의 차이점은 무엇입니까? -
[ 코드베이스는 특정 소프트웨어 또는 응용 프로그램을 구축하는 데 사용되는 전체 소스 코드 모음을 나타냅니다. 여기에는 모든 버전의 코드 및 분기가 포함됩니다. 반면 소스 코드는 현재 처리중인 코드 기반의 일부입니다. 프로그래밍 언어로 작성된 코드이며 실행 가능한 프로그램으로 컴파일했습니다. ]-
- 코드 기반의 커밋 변경은 어떻게 작동합니까?
-
코드 기반의 변경 제출에는 소스 코드를 변경 한 다음 해당 변경 사항을 코드 기반에 저장하는 것이 포함됩니다. 이 프로세스는 일반적으로 GIT와 같은 버전 제어 시스템에서 수행됩니다. 변경 사항을 제출할 때 실제로 해당 시점에서 작업의 스냅 샷을 찍는 것입니다. 이를 통해 변경 사항을 추적하고 필요한 경우 이전 버전으로 복원 할 수 있습니다.
올바른 방식으로 변경 사항을 제출하는 것의 중요성은 무엇입니까?
올바른 방식으로 변경하는 것은 코드 기반의 무결성을 유지하는 데 중요합니다. 코드 기반을 깨끗하고 관리하기 쉽게 유지하여 다른 개발자가 코드를 이해하고 처리 할 수 있도록합니다. 또한 변경 사항을 추적하고 오류가 코드에 도입되는시기와 위치를 식별하는 데 도움이됩니다.
- 변경 사항을 제출하기위한 모범 사례는 무엇입니까?
변경 사항을 제출하기위한 몇 가지 모범 사례에는 작고 점진적인 커밋, 명확하고 설명적인 커밋 정보 작성, 제출 전 변경 사항을 테스트하는 것이 포함됩니다. 충돌을 피하기 위해 로컬 코드베이스를 메인 코드베이스와 정기적으로 동기화하는 것이 중요합니다.
버전 제어 시스템은 무엇이며 코드 기반과 어떤 관련이 있습니까?
버전 제어 시스템은 코드베이스 변경을 관리하는 데 도움이되는 도구입니다. 특수 유형의 데이터베이스에서 모든 수정을 코드로 추적합니다. 오류가 발생하면 개발자는 시간을 되 살리고 이전 버전의 코드를 비교하여 모든 팀원에게 미치는 영향을 최소화하면서 오류를 해결하는 데 도움이됩니다.
-
변경 사항을 제출할 때 충돌을 피하는 방법은 무엇입니까?
는 로컬 코드 기반을 기본 코드베이스와 정기적으로 동기화하여 충돌을 피할 수 있습니다. 이를 통해 항상 최신 버전의 코드를 작업하고 있습니다. 또한 팀과 의사 소통하여 모든 사람이 변경 사항을 알리는 것이 중요합니다.
소프트웨어 개발에서 코드베이스의 역할은 무엇입니까?
-
코드 라이브러리는 소프트웨어 개발에 중요한 역할을합니다. 모든 소스 코드의 중심 저장소 역할을하므로 개발자가 함께 협력하고 소프트웨어의 다른 부분을 동시에 처리 할 수 있습니다. 또한 변화를 추적하고 프로젝트 기록을 유지하는 데 도움이됩니다.
코드베이스와 코드 저장소의 차이점은 무엇입니까?
코드 라이브러리는 소프트웨어의 전체 소스 코드 모음을 나타냅니다. 코드 저장소는이 코드가 저장 및 관리되는 위치입니다. 코드 저장소에는 일반적으로 버전 제어 시스템에서 관리하는 여러 코드 저장소가 포함될 수 있습니다.
- 제출이 의미 있고 유용한 지 확인하는 방법은 무엇입니까?
커밋이 의미 있고 유용한 지 확인하려면 작고 점진적인 커밋을 만드는 것이 중요하며 각 커밋에는 고유 한 목적이 있습니다. 각 커밋은 단일 논리적 변경을 나타냅니다. 또한 변경 사항과 이유를 설명하는 명확하고 설명적인 제출물을 작성하는 것도 중요합니다.
코드 기반과 빌드의 관계는 무엇입니까?
빌딩은 소스 코드를 코드 기반에서 실행 가능한 프로그램으로 변환하는 프로세스입니다. 코드베이스는 빌드 프로세스에 대한 입력이며 출력은 컴퓨터에 설치 및 실행할 수있는 소프트웨어 제품입니다. 빌드 프로세스에는 컴파일 코드, 라이브러리 연결 및 배포 용 포장 소프트웨어가 포함될 수 있습니다.
위 내용은 올바른 방법으로 코드베이스에 변경 사항을 커밋하십시오의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!