Git是一個免費的開放源碼的分布式版本控制系統,用于處理從小到大的項目,速度和效率的一切。Git易于學習,具有閃電般快速的性能,占地面積小。它超越了像Subversion、CVS、Perforce和ClearCase這樣的SCM工具,具有便宜的本地分支,便利的分段區域和多個工作流等功能。

Git gui則是Git的圖形化操作界面,它使用更方便快捷,也不用記憶冗雜的命令,采用了分布式版本庫的作法,不需要服務器端軟件,就可以運作版本控制,使得源代碼的發布和交流極其方便,有興趣的朋友請下載使用。

功能特色

1、分支和合并

Git功能真正讓它與幾乎所有其他SCM分開,其分支模式。

Git允許并鼓勵您擁有可以完全獨立于彼此的多個本地分支。這些開發線的創建,合并和刪除需要幾秒鐘的時間。

這意味著你可以做如下事情:

①無摩擦上下文切換。創建一個分支,嘗試一個想法,提交幾次,切換回分支的地方,應用補丁,切換回您正在嘗試的地方,并將其合并。

基于角色的編碼。有一個分支,總是只包含生產,另一個你合并工作進行測試,和幾個較小的日常工作。

②基于特征的工作流程。為您正在處理的每個新功能創建新的分支,以便您可以無縫地在它們之間切換,然后在該功能合并到主線中時刪除每個分支。

③一次性實驗。創建一個分支進行實驗,意識到它不會工作,只是刪除它 - 放棄工作,沒有人看到它(即使你已經推動其他分支機構)

值得注意的是,當您推送到遠程存儲庫時,您不必推送所有分支。您可以選擇分享您的一個分支,其中一個分支,或其中一個分支。這樣做往往可以讓人們嘗試新的想法,而不用擔心要計劃如何和何時合并或者與他人分享。

有其他系統可以完成其中的一些工作,但涉及的工作要困難得多,容易出錯。Git使這個過程變得非常簡單,它改變了大多數開發人員在學習的時候工作的方式。

2、小而快

使用Git,幾乎所有的操作都是在本地進行的,這給集中式系統帶來了巨大的速度優勢,這些系統不斷與某個服務器進行通信。

Git被建立在Linux內核上,這意味著它必須從第一天有效地處理大型存儲庫。Git是用C編寫的,減少了與更高級語言相關的運行時間的開銷。從一開始,速度和性能一直是Git的主要設計目標。

3、分散式

任何分布式SCM(包括Git)的**功能之一就是分發。這意味著,不要對源代碼的當前提示進行“檢出”,而是對整個存儲庫進行“克隆”。

①多個備份

這意味著即使您使用集中式工作流程,每個用戶本質上都具有主服務器的完整備份。在發生崩潰或損壞的情況下,可以將這些副本推送到主服務器。實際上,除了只有存儲庫的一個副本,Git沒有單點故障。

②任何工作流程

由于Git具有分布式的性質和卓越的分支系統,可以相對容易地實現幾乎無數的工作流程。

③Subversion樣式工作流程

集中的工作流程非常普遍,特別是從集中式系統轉型的人員。如果有人自上次提取以來,Git不會推送,所以所有開發人員推送到同一服務器的集中式模式工作正常。

④集成管理器工作流程

另一個常見的Git工作流程涉及一個集成管理器 - 一個承諾到“保佑”存儲庫的人員。然后,許多開發人員從該存儲庫克隆,推送到他們自己的獨立存儲庫,并要求集成商提取其更改。這是開放源代碼或GitHub存儲庫經??吹降拈_發模式的類型。

⑤獨裁者和中尉工作流程

對于更大規模的項目,像Linux內核的開發工作流通常是有效的。在這個模型中,有些人(“中尉”)負責項目的一個特定子系統,并且在與該子系統有關的所有變化中進行合并。另一個整合者(“獨裁者”)可以從他/她的中尉中抽出變化,然后推到“保佑”的存儲庫,然后每個人再次克隆。

4、數據保證

Git使用的數據模型確保項目每一位的加密完整性。每個文件和提交都被檢出并被檢出,并在檢出時被檢出。除了您提供的確切位置之外,不可能從Git中獲得任何東西。

在Git存儲庫中更改任何文件,日期,提交消息或任何其他數據也是不可能的,而不更改其后的所有ID。這意味著如果你有一個提交ID,你可以放心,不僅你的項目是完全一樣的,當它被提交,但它的歷史沒有改變。

大多數集中版本控制系統默認情況下不提供這樣的完整性。

5、分期區

與其他系統不同,Git有一些稱為“暫存區”或“索引”的東西。這是一個中間區域,可以在完成提交之前格式化和審核提交。

將Git與其他工具分開的一件事是,可以快速執行一些文件并提交它們,而無需提交工作目錄中的所有其他修改的文件,或者必須在提交期間在命令行中列出它們。

這允許您僅對已修改文件的部分進行分段。在您意識到您忘記提交其中一個文件之前,對文件進行兩個邏輯上無關的修改的日子已經過去了?,F在,您可以對當前提交所需的更改進行調整,并對下一次提交進行其他更改。此功能可根據需要擴展到您的文件的許多不同的更改。

當然,如果您不想要這種控件,Git也可以輕松忽略此功能,只需在commit命令中添加一個“-a”,以便將所有文件的所有更改添加到暫存區域。

6、自由和開源

Git是根據GNU通用公共許可證版本2.0發布的,這是一個開源許可證。Git項目選擇使用GPLv2來保證您自由分享和更改免費軟件,以確保所有用戶免費使用該軟件。

Git gui使用教程

1、在本地新建一個文件夾test,選中后點擊右鍵,選擇Git GUI Here,出現下圖,選擇第二個,克隆已經存在的倉庫

2、填寫Source Location(源地址)和Target Directory

3、完成克?。?

點擊上圖的clone后,會提示下輸入你github的用戶名和密碼,出現下面的界面,克隆完成。你可以看看你本地克隆的文件。

更新日志

v2.47.1版本

* 在“git log -L.. -p”已經被發現并修復了

* 在macOS上,fsmonitor可能會陷入競爭條件,導致一個客戶端永遠等待被通知的事件,

* “git maintenance start”由于未初始化的變量而崩潰參考,已更正。

* 在嘗試寫入將損壞的核心索引的內容作為樹對象。

* 從超級項目到子模塊的“git fetch”當默認遠程名稱設置不同時,遠程錯誤

* “gitk”項目樹已再次與其新的維護者約翰內斯·西克特

Git gui官方破解版下載-Git gui(Git客戶端)下載 v2.47.1下載地址

遠程下載