设为首页 加入收藏

TOP

对Link Map File的初步认识(二)
2019-08-31 00:20:29 】 浏览:92
Tags:Link Map File 初步 认识
100003C68 0x00000010 __DATA __objc_selrefs 0x100003C78 0x00000008 __DATA __objc_classrefs 0x100003C80 0x00000008 __DATA __objc_superrefs 0x100003C88 0x00000008 __DATA __objc_ivar 0x100003C90 0x000000A0 __DATA __objc_data 0x100003D30 0x000000C0 __DATA __data

单从字面含义理解:每个Section包含了Address、Size、Segment以及Section。介绍之前,这里先简单介绍一下Mach-O文件。
上面第一部分的Path是可执行文件的路径,使用iTerm进去到该文件夹,然后使用file命令即可查看该文件的类型:

file LinkMapTest

输出结果为:

LinkMapTest: Mach-O 64-bit executable x86_64

可以知道该文件是一个Mach-O格式的文件,它是iOS系统应用执行文件格式。Mach-O文件中的虚拟地址最终会被映射到物理地址上,这些地址会被分为不同的段类型:_ _ TEXT 、_ _ DATA以及_ _ LINKEDIT等。各个段的含义如下:

  1. _ _ TEXT包含了被执行的代码。这些代码是只读、可执行
  2. _ _ DATA包含了包含了将会被更改的数据,例如全局变量、静态变量等,可读写,但是不可执行
  3. _ _ LINKEDIT 包含了加载程序的元数据,比如函数名称和地址,只读。

Segment又被划分成了不同的Section,不同的Section存储了不同的信息,例如 _ _ objc _ methname 为方法的名称。
再回顾上面的Sections,Address是起始位置、Size是大小、Segment是段、Section。

5. Symbols

# Address   Size        File  Name
0x100001730 0x0000003C  [  2] -[ViewController viewDidLoad]
0x100001770 0x00000092  [  3] _main
0x100001810 0x00000080  [  4] -[AppDelegate application:didFinishLaunchingWithOptions:]
0x100001890 0x00000040  [  4] -[AppDelegate applicationWillResignActive:]
0x1000018D0 0x00000040  [  4] -[AppDelegate applicationDidEnterBackground:]
0x100001910 0x00000040  [  4] -[AppDelegate applicationWillEnterForeground:]
0x100001950 0x00000040  [  4] -[AppDelegate applicationDidBecomeActive:]
0x100001990 0x00000040  [  4] -[AppDelegate applicationWillTerminate:]
0x1000019D0 0x00000020  [  4] -[AppDelegate window]
0x1000019F0 0x00000040  [  4] -[AppDelegate setWindow:]
0x100001A30 0x00000033  [  4] -[AppDelegate .cxx_destruct]
0x100001A64 0x00000006  [  5] _NSStringFromClass
0x100001A6A 0x00000006  [  7] _UIApplicationMain
0x100001A70 0x00000006  [  6] _objc_autoreleasePoolPop
0x100001A76 0x00000006  [  6] _objc_autoreleasePoolPush
0x100001A7C 0x00000006  [  6] _objc_msgSendSuper2
0x100001A82 0x00000006  [  6] _objc_retainAutoreleasedReturnValue
0x100001A88 0x00000006  [  6] _objc_storeStrong
0x100001A90 0x00000010  [  0] helper helper
0x100001AA0 0x0000000A  [  5] _NSStringFromClass
0x100001AAA 0x0000000A  [  6] _objc_autoreleasePoolPop
0x100001AB4 0x0000000A  [  6] _objc_autoreleasePoolPush
0x100001ABE 0x0000000A  [  6] _objc_msgSendSuper2
0x100001AC8 0x0000000A  [  6] _objc_retainAutoreleasedReturnValue
0x100001AD2 0x0000000A  [  6] _objc_storeStrong
0x100001ADC 0x0000000A  [  7] _UIApplicationMain
0x100001AE6 0x0000000C  [  2] literal string: viewDidLoad
. . .

根据Sections的起始地址,可以将Symbols分为Sections个数的组,例如0x100001730到0x100001A64之间,就是 _ _ test代码区。
Symbols包含的信息有:

  1. Address:起始地址
  2. Size:所占内存大小,这里使用16进制表示。
  3. File:该Name所在的文件编号,也就是Object files部分的中括号的数字,例如-[ViewController viewDidLoad]对应的文件编号为2,根据Object files部分可以看到所属的文件为:ViewController.o。这样可以计算某个o文件所占内存的大小。只需要把Symbols中编号为o编号Symbols累加统计即可。
  4. Name就是该Sybmols的名称。

6. Dead Stripped Symbols

# Dead Stripped Symbols:
#           Size        File  Name
<<dead>>    0x00000018  [  2] CIE
<<dead>>    0x00000018  [  3] CIE
<<dead>>    0x00000006  [  4] literal string: class
<<dead>>    0x00000008  [  4] literal string: v16@0:8
<<dead>>    0x00000018  [  4] CIE
. . .

在使用linkmap计算内存占比的时候,不要把Dead Stripped Symbols计算在内,因为它们是链接器认为无用的符号,链接的时候不会记入。
上面便是对Link map file做了简单的介绍。

iOS Tools

花了两天的时间,根据对Link Map File的学习,使用Ruby写了一个脚本文件,可以方便地统计出指定Link Map File中的组

首页 上一页 1 2 3 下一页 尾页 2/3/3
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇Windows下修改iTunes备份路径 下一篇Object C学习笔记12-集合

最新文章

热门文章

Hot 文章

Python

C 语言

C++基础

大数据基础

linux编程基础

C/C++面试题目