1. 程式人生 > >Linux下9種優秀的程式碼比對工具推薦

Linux下9種優秀的程式碼比對工具推薦

大家好,我是良許。 在我們編寫程式碼的時候,我們經常需要知道兩個檔案之間,或者同一個檔案不同版本之間有什麼差異性。在 Windows 下有個很強大的工具叫作 BeyondCompare ,那在 Linux 下需要用到什麼工具呢? 本文介紹 9 種 Linux 下常用的 9 種程式碼比對工具,不僅有命令列工具,還有 GUI 介面工具,讓你輕鬆進行程式碼比對。 #### 1. diff命令 `diff` 命令是 Linux 下自帶的一個強大的文字比對工具,而且使用起來非常方便。對於它的使用,我之前也單獨寫過一篇文章介紹,點選下方連結可以檢視。 [教你一招Linux下文字比對方法](https://mp.weixin.qq.com/s?__biz=MzU3NTgyODQ1Nw==&mid=2247485218&idx=1&sn=620d5acbe9424b744712821867be3b61&chksm=fd1c7fa4ca6bf6b2476ab3316b0b81c087a59f9004b59d2e693a87f7cf47062244997165dd4d&token=988970679&lang=zh_CN#rd) diff 命令在大多數的 Linux 發行版裡已經預裝了,它可以逐行比對兩個文字檔案,並輸出它們的差異點。更多介紹可以直接檢視它的 man 手冊。 ``` $ man diff ``` 但是,diff 命令雖然強大,但它的輸出結果實在是太感人了,不直觀也不清晰。於是,有大佬為了彌補這個缺點,基於 diff 開發了更強大的工具。這裡推薦兩個:`colordiff` 和 `wdiff` 。 ##### colordiff命令 `colordiff` 是一個 Perl 指令碼工具,它的輸出結果和 diff 命令一樣,但是會給程式碼著色,並且具有語法高亮功能。同時,你如果不喜歡它的預設顏色的話,還可以自定義主題。 你可以自行安裝 colordiff 到你的電腦,根據不同的發行版選擇不同的安裝命令。 ``` $ yum install colordiff [On CentOS/RHEL/Fedora] $ dnf install colordiff [On Fedora 23+ version] $ sudo apt-get install colordiff [On Debian/Ubuntu/Mint] ``` 同樣,你可以使用 man 命令檢視它的幫助文件: ``` $ man colordiff ``` ##### wdiff命令 diff 命令是逐行比較差異,而 `wdiff` 更變態,是逐字比較。所以如果你的文字只是修改了少數一些詞語的話,使用 wdiff 命令將更加高效。 安裝命令如下: ``` $ yum install wdiff [On CentOS/RHEL/Fedora] $ dnf install wdiff [On Fedora 23+ version] $ sudo apt-get install wdiff [On Debian/Ubuntu/Mint] ``` 更詳細內容可以檢視它的 man 手冊。 ``` $ man wdiff ``` #### 2. vimdiff命令 `vimdiff` 等同於 `vim -d` 命令,即 Vim 編輯器的 diff 模式。 該命令後面通常會接兩個或多個檔名作為引數,這些檔案會同時在 Vim 編輯器的分割視窗中開啟,並高亮顯示檔案中內容有差異的部分。 ![](https://img2020.cnblogs.com/other/1218435/202006/1218435-20200624201719645-422943716.jpg) 它的中文主頁是:http://vimcdoc.sourceforge.net/doc/diff.html 以上介紹的兩款是 Linux 命令列的對比工具,我們再來看一些 GUI 比對工具。 #### 3. Kompare `Kompare` 是基於 diff 的一個 GUI 工具,使用者可以很方便看到檔案之間的差異,並且支援合併這些差異。 Kompare 的特性有如下: - 支援多種 diff 格式; - 支援目錄之間的比對; - 支援讀取 diff 檔案; - 自定義介面; - 建立及應用原始檔的 patch 檔案。 ![](https://img2020.cnblogs.com/other/1218435/202006/1218435-20200624201719998-1092250858.jpg) 該工具的主頁為:https://www.kde.org/applications/development/kompare/ #### 4. DiffMerge `DiffMerge` 是一個跨平臺的 GUI 文字比對工具,具有 Linux ,Windows ,macOS 三大平臺版本。我們知道,BeyondCompare 是一款收費軟體,所以如果你們公司的版權要求比較高的話,不妨考慮一下 DiffMerge工具。 DiffMerge 具有兩大功能:1. 圖示化顯示兩個檔案之間的改變。包含內部行高亮和完整的編輯支援。2. 圖示化顯示三個檔案之間的改變。允許自動合併(當可以安全操作時)和對結果檔案完全編輯控制。 它具有以下特性: - 支援資料夾比對; - 整合檔案瀏覽器; - 高度可配置。 ![](https://img2020.cnblogs.com/other/1218435/202006/1218435-20200624201720583-209285513.jpg) 該工具的主頁為:https://sourcegear.com/diffmerge/ #### 5. Meld `Meld` 是一個輕量級 GUI 程式碼比對工具,它支援使用者比對檔案、目錄,並且高度整合版本控制軟體。但針對軟體開發人員,它的以下幾個特性尤為吸引人: - 執行雙向和三向差異併合並 - 輕鬆地在差異和衝突之間導航 - 逐個檔案地比較兩個或三個目錄,顯示新檔案,缺失檔案和更改檔案 - 支援許多版本控制系統,包括 Git,Mercurial,Bazaar 和 SVN 等。 ![](https://img2020.cnblogs.com/other/1218435/202006/1218435-20200624201720976-620420268.jpg) 它的官網為:http://meldmerge.org/ #### 6. Diffuse `Diffuse` 是另外一款很受歡迎的,免費,小巧,也十分簡單的 GUI 文字差異比對合並工具,它是用 Python 寫成的,具有兩個主要功能:檔案比對及版本控制,允許檔案編輯、合併,並且輸出兩個檔案的差異點。 你可以使用它檢視文字比對小結,使用滑鼠選擇檔案裡的某行進行編輯。它的其它特性包括: - 語法高亮 - 快捷鍵便於文字導航 - 無限次撤銷 - 支援 unicode 編碼檔案 - 支援許多版本控制系統,包括 Git,Mercurial,Bazaar 和 SVN 等。 ![](https://img2020.cnblogs.com/other/1218435/202006/1218435-20200624201721382-502806013.jpg) 它的官網為:http://diffuse.sourceforge.net/ #### 7. XXdiff `XXdiff` 是一款免費、強大的檔案及資料夾差異比對及合併工具,它可以執行在很多類 Unix 系統上。不過它有個限制就是它不支援 unicode 檔案,也沒法辦法直接編輯檔案。 它具有以下特性: - 遞迴對比檔案及資料夾 - 高亮顯示差異點 - 合併差異點,匯出結果 - 支援外部 diff 工具,比如:GNU diff,SIG diff ,Cleareddiff ,以及其它更多工具 - 支援指令碼拓展 ![](https://img2020.cnblogs.com/other/1218435/202006/1218435-20200624201721807-1375789383.jpg) #### 8. KDiff3 `KDiff3` 是另外一種很強大的跨平臺差異比對及合併工具,它是由 `KDevelop` 開發而成,可以在所有類 Unix 平臺上執行,包括 Linux ,Mac OS ,Windows 等。 它可以比對或合併兩到三個檔案或目錄,具有以下特性: - 可以逐句、逐字對比差異 - 支援自動合併 - 內建編輯器,可以手動解決衝突 - 支援 unicode ,UTF-8 等各種編碼格式 - 支援列印差異 ![](https://img2020.cnblogs.com/other/1218435/202006/1218435-20200624201722087-595687786.jpg) 它的官網為: http://kdiff3.sourceforge.net/ #### 9. TkDiff `TkDiff` 是另外一種跨平臺,易於使用的 GUI 文字比對工具,可以執行在 Linux ,Windows 及 MacOS 系統上。它同樣提供一個左右分開的介面,用於檢視對比的兩個檔案。 但是,它也有一些其它文字對比工具沒有的功能,比如差異書籤,以及一個便於快速定位導航差異點的導航圖。 ![](https://img2020.cnblogs.com/other/1218435/202006/1218435-20200624201722419-443255094.jpg) 它的官網為:https://sourceforge.net/projects/tkdiff/ --- 公眾號:良許Linux ### 有收穫?希望老鐵們來個三連擊,給更多的人看到這