點擊「閱讀原文」查看良許原創精品視頻。

大家好,我是良許。

在我們編寫代碼的時候,我們經常需要知道兩個文件之間,或者同一個文件不同版本之間有什麼差異性。在 Windows 下有個很強大的工具叫作 BeyondCompare ,那在 Linux 下需要用到什麼工具呢?

本文介紹 9 種 Linux 下常用的 9 種代碼比對工具,不僅有命令行工具,還有 GUI 界面工具,讓你輕鬆進行代碼比對。

1

diff命令

diff  命令是 Linux 下自帶的一個強大的文本比對工具,而且使用起來非常方便。對於它的使用,我之前也單獨寫過一篇文章介紹,點擊下方鏈接可以查看。

教你一招Linux下文本比對方法

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

vimdiff命令

vimdiff  等同於  vim -d  命令,即 Vim 編輯器的 diff 模式。

該命令後面通常會接兩個或多個文件名作爲參數,這些文件會同時在 Vim 編輯器的分割窗口中打開,並高亮顯示文件中內容有差異的部分。

它的中文主頁是: http://vimcdoc.sourceforge.net/doc/diff.html

以上介紹的兩款是 Linux 命令行的對比工具,我們再來看一些 GUI 比對工具。

3

Kompare

Kompare  是基於 diff 的一個 GUI 工具,使用者可以很方便看到文件之間的差異,並且支持合併這些差異。

Kompare 的特性有如下:

  • 支持多種 diff 格式;

  • 支持目錄之間的比對;

  • 支持讀取 diff 文件;

  • 自定義界面;

  • 創建及應用源文件的 patch 文件。

該工具的主頁爲: https://www.kde.org/applications/development/kompare/

4

DiffMerge

DiffMerge  是一個跨平臺的 GUI 文本比對工具,具有 Linux ,Windows ,macOS 三大平臺版本。我們知道,BeyondCompare 是一款收費軟件,所以如果你們公司的版權要求比較高的話,不妨考慮一下 DiffMerge工具。

DiffMerge 具有兩大功能:1. 圖示化顯示兩個文件之間的改變。包含內部行高亮和完整的編輯支持。2. 圖示化顯示三個文件之間的改變。允許自動合併(當可以安全操作時)和對結果文件完全編輯控制。

它具有以下特性:

  • 支持文件夾比對;

  • 集成文件瀏覽器;

  • 高度可配置。

該工具的主頁爲: https://sourcegear.com/diffmerge/

5

Meld

Meld  是一個輕量級 GUI 代碼比對工具,它支持用戶比對文件、目錄,並且高度集成版本控制軟件。但針對軟件開發人員,它的以下幾個特性尤爲吸引人:

  • 執行雙向和三向差異併合並

  • 輕鬆地在差異和衝突之間導航

  • 逐個文件地比較兩個或三個目錄,顯示新文件,缺失文件和更改文件

  • 支持許多版本控制系統,包括 Git,Mercurial,Bazaar 和 SVN 等。

它的官網爲: http://meldmerge.org/

6

Diffuse

Diffuse  是另外一款很受歡迎的,免費,小巧,也十分簡單的 GUI 文本差異比對合並工具,它是用 Python 寫成的,具有兩個主要功能:文件比對及版本控制,允許文件編輯、合併,並且輸出兩個文件的差異點。

你可以使用它查看文本比對小結,使用鼠標選擇文件裏的某行進行編輯。它的其它特性包括:

  • 語法高亮

  • 快捷鍵便於文本導航

  • 無限次撤銷

  • 支持 unicode 編碼文件

  • 支持許多版本控制系統,包括 Git,Mercurial,Bazaar 和 SVN 等。

它的官網爲: http://diffuse.sourceforge.net/

7

XXdiff

XXdiff  是一款免費、強大的文件及文件夾差異比對及合併工具,它可以運行在很多類 Unix 系統上。不過它有個限制就是它不支持 unicode 文件,也沒法辦法直接編輯文件。

它具有以下特性:

  • 遞歸對比文件及文件夾

  • 高亮顯示差異點

  • 合併差異點,導出結果

  • 支持外部 diff 工具,比如:GNU diff,SIG diff ,Cleareddiff ,以及其它更多工具

  • 支持腳本拓展

8

KDiff3

KDiff3  是另外一種很強大的跨平臺差異比對及合併工具,它是由  KDevelop  開發而成,可以在所有類 Unix 平臺上運行,包括 Linux ,Mac OS ,Windows 等。

它可以比對或合併兩到三個文件或目錄,具有以下特性:

  • 可以逐句、逐字對比差異

  • 支持自動合併

  • 內置編輯器,可以手動解決衝突

  • 支持 unicode ,UTF-8 等各種編碼格式

  • 支持打印差異

它的官網爲:  http://kdiff3.sourceforge.net/

9

TkDiff

TkDiff  是另外一種跨平臺,易於使用的 GUI 文本比對工具,可以運行在 Linux ,Windows 及 MacOS 系統上。它同樣提供一個左右分開的界面,用於查看對比的兩個文件。

但是,它也有一些其它文本對比工具沒有的功能,比如差異書籤,以及一個便於快速定位導航差異點的導航圖。

它的官網爲: https://sourceforge.net/projects/tkdiff/

良許個人微信

添加良許個人微信即送3套程序員必讀資料

→ 精選技術資料共享

→ 高手如雲交流社羣

本公衆號全部博文已整理成一個目錄,請在公衆號裏回覆「 m 」獲取!

推薦閱讀:

拍一拍,微信史上最短一行代碼

Linux下如何尋找相同文件?

有點厲害!用12萬行代碼堆出來個"蔡徐坤",編譯還能通過!

5T技術資源大放送!包括但不限於:C/C++,Linux,Python,Java,PHP,人工智能,單片機,樹莓派,等等。在公衆號內回覆「 1024 」,即可免費獲取!!

相關文章