热门问题
时间线
聊天
视角
ar (Unix)
来自维基百科,自由的百科全书
Remove ads
ar(archiver)是Unix系統上的歸檔工具,用於將多個文件歸檔為一個文件。ar
目前一般僅被鏈接器用創建更新靜態庫和生成.deb包。它的歸檔功能現在基本被 tar
所取代。[3] GNU Binutils包含ar
.[2]
Linux標準規範(LSB)中,ar
已被棄用,並可能在將來的版本中移除,理由是LSB不應包含軟件開發工具和指定.o和.a文件格式。[4]
Remove ads
文件格式

ar格式從未標準化過,歷史上有過多種形式[5] 如 V6, V7, AIX和Coherent等,與通用格式都有很大的差別。[6]現在的通用格式主要基於兩種變體:BSD 和 System V(最初稱為 COFF,也被 GNU, ELF和Windows使用。)Debian的 ".deb" 使用通用格式。
.ar文件起始是一個全局文件頭,接着是各個文件的文件頭和數據部分。數據部分為2字節對齊,如果數據長度為奇數,則填充一個換行符(\n,0x0A)。
為 "!<arch>"
和換行符(0x0A).
歸檔的每個文件包含文件頭存儲文件信息。下表為通用格式。數值為ASCII編碼,並用空格(0x20)向右填充。
標頭全部為可打印的ASCII字符和換行符,所以只包含文本文件的ar歸檔文件仍然是文本文件。
每個文件從偶數字節開始,如果長度為奇數,則需要填充一個換行符,文件頭中的文件大小存儲是實際大小。[7]
由於文件名長度和格式的限制,GNU和BSD變體都設計了不同的存儲長文件名的方法。儘管通用格式不會受到2038年問題的困擾,但很多系統上的ar程序存在這種問題,可能需要修改以正確處理超過2147483647的時間戳。有關這些擴展的說明,請參見libbfd。[8]
根據格式的不同,許多ar實現了用於快速鏈接的全局符號表(armap,目錄或索引)而無需掃描整個存檔中的符號。POSIX識別此功能,並且要求ar實現具有 -s
選項更新符號表。大多數實現將其放在第一個文件條目中。[9]
BSD ar 在文件名頭填充ASCII空格符,文件名如包含空格會有問題。4.4BSD ar將"#1/"和文件名長度放置在文件名字段,並將文件名放置在數據段的最前面[6]
BSD ar 自身不處理全局符號查找表,而使用單獨的工具ranlib[10]。ranlib會插入一個與系統架構相關的文件 __.SYMDEF
作為第一個文件[11] 一些後來的版本會在名稱後面放置一個空格和"SORTED"字符表示已排序。[12] Darwin 64位系統使用__.SYMDEF_64
。
由於POSIX規範要求-s
選項,新的BSD ar 重新實現了該要求。FreeBSD 棄用了 SYMDEF 表而採用 System V 類型的查找表。[13]
System V ar 用字符'/'(0x2F)標記文件名結束,從而文件名可以使用空格。需要擴展的文件將文件名存儲在"//"文件的數據段,在標頭文件名字段中寫入'/'和十進制的偏移地址。 "//"文件包含的是長文件名列表,以換行符分割。通常 "//" 是第二個條目,符號表為第一個條目。
System V ar 用 "/" 文件名表示對應的數據為符號查找表,包含三部分,並存儲為連續的數據。
有些 System V ar不使用上述各式,如HP-UX 11.0,上述信息存儲為 SOM文件格式。
為解決4GiB文件限制,某些系統如Solaris 11.2 和 GNU使用不同的查找表。不同之處在於使用64位整數和用"/SYM64/"代替"/"[14]
Remove ads
Windows的PE/COFF格式基於 System V/GNU。 第一個條目為 "/" 與System V/GNU符號表相同。第二個條目也是"/",使用小端整數,表示ECOFF擴展,用於存儲經過排序的符號交叉引用表。 [5][15] 第三個條目為 "//" 長文件名數據。[16]
GNU binutils和elfutils中的 ar
有一個 "thin archive" 格式,特徵簽名為 !<thin>
,僅包含符號表和對該文件的引用。[17]
參見
參考
外部連結
Wikiwand - on
Seamless Wikipedia browsing. On steroids.
Remove ads