十六進制轉儲
此條目沒有列出任何參考或來源。 (2017年7月29日) |
在電腦運算領域,十六進制轉儲(英文:Hex dump)是指從內存或其他存儲設備中調取的數據的十六進制視圖(該視圖被列印在屏幕上或者紙上)。在調試軟體及進行反向工程時,操作者經常需要查閱十六進制轉儲。
在十六進制轉儲中,每個字節被兩位十六進制數字代表。十六進制轉儲在顯示時通常被排列成8或16位元組的列,有時用空格隔開。一些十六進制轉儲工具在行首提供十六進制的內存地址,有些則在行尾提供檢驗值。
雖然十六進制轉儲的名稱中包含「十六進制」,但是一些十六進制轉儲軟體也提供八進制或者十進制的輸出選項。常用的十六進制轉儲工具包括 hexdump、od、xxd,有時這些軟體也會被簡單地命名為 dump 或者 D。
例子
編輯一個程序十六進制轉儲的一部分(用 Unix 的 hexdump 工具生成):
00105e0 e6b0 343b 9c74 0804 e7bc 0804 e7d5 0804 00105f0 e7e4 0804 e6b0 0804 e7f0 0804 e7ff 0804 0010600 e80b 0804 e81a 0804 e6b0 0804 e6b0 0804
上面的列子展示了十六進制轉儲的一種形式。但是十六進制轉儲不僅局限於如上形式,其字節序可以不同。以下的形式則僅在特定情形下使用:
00105e0 e6 b008 04e79e08 04e7bc 08 04 e7 d50804
當必需明確字節的順序時(如查閱進行機器語言程序或者 ROM時),則更傾向於逐字節地列出,每16位元組一行,並可能用分隔符分成兩個8位元組的組:
00105e0 e6 b0 08 04 e7 9e 08 04-e7 bc 08 04 e7 d5 08 04 00105f0 e7 e4 08 04 e6 b0 08 04-e7 f0 08 04 e7 ff 08 04 0010600 e8 0b 08 04 e8 1a 08 04-e6 b0 08 04 e6 b0 08 04
在一些情況下,也會用不在值之間留空白的形式表示:
00105e0 e6b00804e79e0804e7bc0804e7d50804 00105f0 e7e40804e6b00804e7f00804e7ff0804 0010600 e80b0804e81a0804e6b00804e6b00804
Unix默認將兩個字節並作一組顯示。以下是在現代化的x86(小端序)計算機上通常的現實情況:
00105e0 b0e6 0408 9ee7 0408 bce7 0408 d5e7 0408 00105f0 e4e7 0408 b0e6 0408 f0e7 0408 ffe7 0408 0010600 0be8 0408 1ae8 0408 b0e6 0408 b0e6 0408
通常,也會有額外的一列表顯示出十六進制數字代表的ASCII碼(例如 hexdump -C
或 hd
):
0000: 57 69 6B 69 70 65 64 69 61 2C 20 74 68 65 20 66 Wikipedia, the f
0010: 72 65 65 20 65 6E 63 79 63 6C 6F 70 65 64 69 61 ree encyclopedia
0020: 20 74 68 61 74 20 61 6E 79 6F 6E 65 20 63 61 6E that anyone can
0030: 20 65 64 69 74 00 00 00 00 00 00 00 00 00 00 00 edit...........
校驗和
編輯當十六進制轉儲需要手動輸入時,便會在每一行的末尾提供一位或兩位校驗和,一般用256模本行中所有數字之和,或者使用 CRC 值。這個校驗和將用於確定用戶的輸入正確與否。
壓縮的重複行
編輯在Unix程序 od 和 hexdump 中,並非所有行都會被列出。包含與上一行相同的內容的行將被略去,取而代之的是一個星號。例如,一塊全是零的信息列印如下:
0000000 0000 0000 0000 0000 0000 0000 0000 0000 * 0000030
這個特性可以使我們很方便地檢測的大文件或存儲設備的不規則情況。在現代 Linux 系統中,使用以下命令可以方便地掃描整個硬碟,以檢查是否完全為空:
# hexdump /dev/sda #(用需要扫描的设备的路径代替/dev/sda)
-v 選項使 hexdump 和 od 顯示所有輸入的數據:
0000000 0000 0000 0000 0000 0000 0000 0000 0000 0000010 0000 0000 0000 0000 0000 0000 0000 0000 0000020 0000 0000 0000 0000 0000 0000 0000 0000
參考資料
編輯外部連結
編輯- hexdump(頁面存檔備份,存於網際網路檔案館) Linux in a Nutshell
- 使用 Hexdump 組件的指南Archive.is的存檔,存檔日期2013-01-16
- 反向 Hex Dump(頁面存檔備份,存於網際網路檔案館) 使用 xxd 命令
- hdr(頁面存檔備份,存於網際網路檔案館) 多功能的十六進制轉儲工具
- Data::HexDump::Range(頁面存檔備份,存於網際網路檔案館) 被 hdr 使用的模塊。
- hexd(頁面存檔備份,存於網際網路檔案館) 另一種十六進制轉儲工具
- RFC 4194 "The S Hexdump Format"