以下由linux教學專欄來介紹Linux下9種優秀的程式碼比對工具,希望對需要的朋友有幫助!
在我們寫程式碼的時候,我們常常需要知道兩個檔案之間,或是同一個檔案不同版本之間有什麼差異性。在 Windows 下有個很強大的工具叫做 BeyondCompare ,那在 Linux 下需要用到什麼工具呢?
本文介紹 9 種 Linux 下常用的 9 種程式碼比對工具,不只命令列工具,還有 GUI 介面工具,讓你輕鬆進行程式碼比對。
diff
指令是 Linux 下自帶的一個強大的文字比對工具,而且使用起來非常方便。對於它的使用,我之前也單獨寫過一篇文章介紹,點擊下方連結可以查看。
教你一招Linux下文字比對方法
diff 指令在大多數的Linux 發行版裡已經預先安裝了,它可以逐行比對兩個文字文件,並輸出它們的差異點。更多介紹可以直接查看它的 man 手冊。
$ man diff
但是,diff 指令雖然強大,但它的輸出結果實在是太感人了,不直覺也不清晰。於是,有大佬為了彌補這個缺點,基於 diff 開發了更強大的工具。這裡推薦兩個:colordiff
和 wdiff
。
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
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
等同於 vim -d
指令,即 Vim 編輯器的 diff 模式。
該指令後面通常會接兩個或多個檔案名稱作為參數,這些檔案會同時在 Vim 編輯器的分割視窗中打開,並高亮顯示檔案中內容有差異的部分。
它的中文首頁是:http://vimcdoc.sourceforge.net/doc/diff.html
以上介紹的兩款是Linux 指令行的比較工具,我們再來看一些GUI 比對工具。
Kompare
是基於 diff 的 GUI 工具,使用者可以很方便地看到檔案之間的差異,並且支援合併這些差異。
Kompare 的特性有如下:
此工具的首頁為:https://www.kde.org/applications/development/kompare/
DiffMerge
是一個跨平台的GUI 文字比對工具,具有Linux ,Windows ,macOS 三大平台版本。我們知道,BeyondCompare 是一款收費軟體,所以如果你們公司的版權要求比較高的話,不妨考慮一下 DiffMerge工具。
DiffMerge 具有兩大功能:1. 圖示化顯示兩個檔案之間的改變。包含內部行高亮和完整的編輯支援。 2. 圖示化顯示三個文件之間的變化。允許自動合併(當可以安全操作時)和對結果檔案完全編輯控制。
它具有以下特性:
工具的首頁為:https://sourcegear.com/diffmerge/
Meld
是一個輕量級GUI 程式碼比對工具,它支援使用者比對檔案、目錄,並且高度整合版本控制軟體。但針對軟體開發人員,它的以下幾個特性特別吸引人:
它的官網為:http://meldmerge.org/
Diffuse
是另外一款很受歡迎的,免費,小巧,也十分簡單的GUI 文字差異比對合併工具,它是用Python 寫成的,具有兩個主要功能:文件比對及版本控制,允許文件編輯、合併,並且輸出兩個檔案的差異點。
你可以使用它來查看文字比對小結,使用滑鼠選擇檔案裡的某行進行編輯。它的其它特性包括:
它的官網為:http://diffuse.sourceforge.net/
XXdiff
是一款免費、強大的檔案及資料夾差異比對及合併工具,它可以運行在許多類Unix 系統上。不過它有個限制就是它不支援 unicode 文件,也沒辦法直接編輯文件。
它具有以下特性:
KDiff3
是另一個很強大的跨平台差異比對及合併工具,它是由KDevelop
開發而成,可以在所有類別Unix 平台上運行,包括Linux ,Mac OS ,Windows 等。
它可以比對或合併兩到三個檔案或目錄,具有以下特性:
它的官網為:http://kdiff3.sourceforge.net/
TkDiff
是另外一種跨平台,易於使用的GUI 文字比對工具,可以運行在Linux ,Windows 及MacOS 系統上。它同樣提供一個左右分開的介面,用於查看對比的兩個文件。
但是,它也有一些其它文字對比工具沒有的功能,例如差異書籤,以及一個便於快速定位導航差異點的導航圖。
它的官網為:https://sourceforge.net/projects/tkdiff/
以上是Linux下9種優秀的程式碼比對工具【推薦】的詳細內容。更多資訊請關注PHP中文網其他相關文章!