Mach-O 文件一

MachO文件

官方介绍总共有11种格式! 是 Mach Object的缩写,是Mac\iOS 上用于存储程序,库的标准格式!

常见的格式:

  • 1.可执行文件
  • 2.objcet
    • .o 文件(目标文件)
    • .a 静态库文件.其实就是N个.o文件的集合
  • 3.DYLIB: 动态库文件
    • dylib
    • framework
  • 4.动态连接器,dynamic linker
  • 5.DSYM :分析 APP 崩溃信息。

演示 C 文件 —> 可执行文件(C 语言基础知识)

  1. 新建一个 test.c 的 C 文件,写一个方法:
int main(){
    printf("测试一下");
    return 0;
}
  1. 编译一下:

clang -c test.c

即生成 test.o 文件。

  1. 再通过 file 命令查看一下:

file test.o

既可以看到,test.o 为 Mach-O 文件,object 文件
test.o: Mach-O 64-bit object x86_64

但是不是一个可执行的文件,怎么变成一个可执行的文件呢?

  1. 通过 clang 链接一下目标文件 test.o 即可:

clang test.o

这时,text.c 就转变成一个 a.out 的可执行文件。

  1. 执行

./a.out

Mach-O 文件一_第1张图片
转换执行过程

补充:

clang -o test1 test.o
链接 test.0 目标文件,生成 test1 的可执行文件

  1. 同 1

clang -o test2 test.c
直接一次性将源文件生成 test2 的可执行文件

Mach-O 文件一_第2张图片
image.png
  1. 同时将多个源文件生成一个可执行文件:

clang -o Demo test.c test1.c
先后顺序无关,文件间方法声明相互调用

  1. 同时将多个源文件生成一个.0 目标文件:

clang -c test.c test1.c

静态库

find . -name "*.a"
在当前目录中查找名字 .a 扩展名的 静态库。

find /usr/lib -name "*.dylib"
在指定目录下查找动态库

动态库共享缓存

为了提高性能,系统的动态库文件都存在了动态库共享缓存里面!

Mach-O 文件一_第3张图片
Mac

动态加载器/连接器(dyld)

  • dynamic linker
  • dynamic loader
Mach-O 文件一_第4张图片
image.png
文件类型

Xcode 中的 Mach-O 文件类型

Mach-O 文件一_第5张图片
Mach-O 文件类型

Mach-O 文件编译架构:

  • Debug 模式:
    手机链接编译,查看 002--可执行文件.app 找到可执行文件,查看:

file 002--可执行文件

002--可执行文件: Mach-O 64-bit executable arm64

Mach-O 文件一_第6张图片
image.png
符号表文件中的可执行文件类型
  • Release 模式:
    会生成 armv7 和 arm64 两种架构。11.4 还是一样的arm64
    开始测试还是arm64,是因为版本的问题,切换到 10.3 就是两种了,如下:
image.png
Mach-O 文件一_第7张图片
image.png

环境变量一般为:arm64 和 armv7.

拆分二进制文件

同时包含了多个架构的二进制文件叫做 通用二进制文件

lipo 经常用于整合静态库

瘦身

  • 拆分名字为 macho_armv7 的 armv7 版本。
$ lipo 002--可执行文件 -thin armv7 -output macho_armv7
  • 拆分名字为 macho_arm64 的 arm64 版本。
$ lipo 002--可执行文件 -thin arm64 -output macho_arm64

整合

  • 合并为 arm64 和 armv7 的版本。
$ lipo -create macho_armv7 macho_arm64 -output machO_v7_64

附:lipo命令

lipo 是一个在 Mac OS X 中处理通用程序(Universal Binaries 即 通用二进制文件)的工具。

使用 lipo 命令来查看整合静态库

  1. 查看静态库支持的CPU架构

lipo -info libname.a(或者libname.framework/libname)

如:lipo -info macho_arm64

  1. 静态库拆分

lipo 静态库源文件路径 -thin CPU架构名称 -output 拆分后文件存放路径(名称)

  • 架构名为armv7/armv7s/arm64等,与lipo -info 输出的架构名一致

如上面的:
$ lipo 002--可执行文件 -thin arm64 -output macho_arm64

  1. 合并静态库

合并多个静态库
lipo -create 静态库存放路径(名称)1 静态库存放路径2 ... -output 整合后存放的路径

framework 合并(例util.framework)
lipo -create arm7/util i386/util -output util.framework

你可能感兴趣的:(Mach-O 文件一)