你們好,我是良許。html
在咱們編寫代碼的時候,咱們常常須要知道兩個文件之間,或者同一個文件不一樣版本之間有什麼差別性。在 Windows 下有個很強大的工具叫做 BeyondCompare ,那在 Linux 下須要用到什麼工具呢?程序員
本文介紹 9 種 Linux 下經常使用的 9 種代碼比對工具,不只有命令行工具,還有 GUI 界面工具,讓你輕鬆進行代碼比對。面試
diff
命令是 Linux 下自帶的一個強大的文本比對工具,並且使用起來很是方便。對於它的使用,我以前也單獨寫過一篇文章介紹,點擊下方連接能夠查看。vim
diff 命令在大多數的 Linux 發行版裏已經預裝了,它能夠逐行比對兩個文本文件,並輸出它們的差別點。更多介紹能夠直接查看它的 man 手冊。安全
$ man diff複製代碼
可是,diff 命令雖然強大,但它的輸出結果實在是太感人了,不直觀也不清晰。因而,有大佬爲了彌補這個缺點,基於 diff 開發了更強大的工具。這裏推薦兩個:colordiff
和 wdiff
。架構
colordiff
是一個 Perl 腳本工具,它的輸出結果和 diff 命令同樣,可是會給代碼着色,而且具備語法高亮功能。同時,你若是不喜歡它的默認顏色的話,還能夠自定義主題。app
你能夠自行安裝 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 編輯器的分割窗口中打開,並高亮顯示文件中內容有差別的部分。
它的中文主頁是:vimcdoc.sourceforge.net/doc/diff.ht…
以上介紹的兩款是 Linux 命令行的對比工具,咱們再來看一些 GUI 比對工具。
Kompare
是基於 diff 的一個 GUI 工具,使用者能夠很方便看到文件之間的差別,而且支持合併這些差別。
Kompare 的特性有以下:
該工具的主頁爲:www.kde.org/application…
DiffMerge
是一個跨平臺的 GUI 文本比對工具,具備 Linux ,Windows ,macOS 三大平臺版本。咱們知道,BeyondCompare 是一款收費軟件,因此若是大家公司的版權要求比較高的話,不妨考慮一下 DiffMerge工具。
DiffMerge 具備兩大功能:1. 圖示化顯示兩個文件之間的改變。包含內部行高亮和完整的編輯支持。2. 圖示化顯示三個文件之間的改變。容許自動合併(當能夠安全操做時)和對結果文件徹底編輯控制。
它具備如下特性:
該工具的主頁爲:sourcegear.com/diffmerge/
Meld
是一個輕量級 GUI 代碼比對工具,它支持用戶比對文件、目錄,而且高度集成版本控制軟件。但針對軟件開發人員,它的如下幾個特性尤其吸引人:
它的官網爲:meldmerge.org/
Diffuse
是另一款很受歡迎的,免費,小巧,也十分簡單的 GUI 文本差別比對合並工具,它是用 Python 寫成的,具備兩個主要功能:文件比對及版本控制,容許文件編輯、合併,而且輸出兩個文件的差別點。
你可使用它查看文本比對小結,使用鼠標選擇文件裏的某行進行編輯。它的其它特性包括:
它的官網爲:diffuse.sourceforge.net/
XXdiff
是一款免費、強大的文件及文件夾差別比對及合併工具,它能夠運行在不少類 Unix 系統上。不過它有個限制就是它不支持 unicode 文件,也無法辦法直接編輯文件。
它具備如下特性:
KDiff3
是另一種很強大的跨平臺差別比對及合併工具,它是由 KDevelop
開發而成,能夠在全部類 Unix 平臺上運行,包括 Linux ,Mac OS ,Windows 等。
它能夠比對或合併兩到三個文件或目錄,具備如下特性:
它的官網爲: kdiff3.sourceforge.net/
TkDiff
是另一種跨平臺,易於使用的 GUI 文本比對工具,能夠運行在 Linux ,Windows 及 MacOS 系統上。它一樣提供一個左右分開的界面,用於查看對比的兩個文件。
可是,它也有一些其它文本對比工具沒有的功能,好比差別書籤,以及一個便於快速定位導航差別點的導航圖。
它的官網爲:sourceforge.net/projects/tk…
最後,最近不少小夥伴找我要Linux學習路線圖,因而我根據本身的經驗,利用業餘時間熬夜肝了一個月,整理了一份電子書。不管你是面試仍是自我提高,相信都會對你有幫助!目錄以下:
免費送給你們,只求你們金指給我點個贊!
也但願有小夥伴能加入我,把這份電子書作得更完美!
推薦閱讀: