大家好,我是良許,
在我們撰寫代碼的時候,我們經常需要知道兩個檔案之間,或者同一個檔案不同版本之間有什么差異性,在 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
2. 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/
公眾號:良許Linux
有識訓?希望老鐵們來個三連擊,給更多的人看到這篇文章
轉載請註明出處,本文鏈接:https://www.uj5u.com/caozuo/47054.html
標籤:Linux
上一篇:C語言實作字串的復制的兩種方法
下一篇:線性表的鏈式存盤--單鏈表
