苹果.tbd格式的文件介绍、生成和使用

简介: 早在2015年苹果推出了Xcode7的时候,.tbd文件也随之产生,它的出现取代了我们熟悉的 .dylib。那么.tbd文件到底是什么呢?有什么用?怎么用?接下来我们一点一点来揭开它的面纱。

早在2015年苹果推出了Xcode7的时候,.tbd文件也随之产生,它的出现取代了我们熟悉的 .dylib。

那么.tbd文件到底是什么呢?有什么用?怎么用?接下来我们一点一点来揭开它的面纱。


1. tbd介绍


tbd全称是text-based stub libraries,本质上就是一个YAML描述的文本文件。YAML是一个可读性高,用来表达数据序列化的格式。


tbd用于记录链接动态库的必要信息,包括动态库导出符号、动态库的架构信息、动态库的依赖信息、动态库的链接路径等。如下图:


image.png


2. tbd生成原理


tbd格式文件,本身是通过Xcode内置工具tapi-installapi专门来生成的,具体路径为:

/Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/tapi installapi


3. tbd文件生成


创建一个名为JQTestTdb.framework这样一个动态库framework,如何生成tbd格式文件?

首先来到Build Setting,找到Text-Based API,将Supports Text-Based InstallAPI设置为Yes:


image.png


然后,通过Other Text-Based InstallAPI Flags给tapi-installapi工具传递参数,常用的参数有:


-ObjC:将输入文件视为Objective-C文件(默认)
    -ObjC++:将输入文件视为Objective-C++文件
    -x<语言>:值为c、c++、Objective-c和Objective-c++
    -Xparser <arg>:传递参数给clang parser。常用参数有:-Wno-deprecated-declarations、-Wno-unavailable-declarations
    -exclude-public-header <path>:引入的需要解析的public头文件路径


image.png


4. tbd文件的使用

第一步,新建一个LoginApp的项目,将JQTestTdb文件夹拷贝到项目根目录下,我们可以看到JQTestTdb文件夹下只有Headers和JQTestTdb.tbd文件,这个也就是要暴露给外部的文件,类似于系统提供的tbd文件


image.png


第二步,在ViewController中引入头文件,在viewDidLoad中打印一下JQTestTdbPerson的实例对象,如下图


image.png


第三步,这时候编译会报错 Undefined symbol:OBJC_CLASS$_JQTestTdbPerson


image.png


我们将JQTestTdb.tbd直接拖到Framework目录下,如下图,再编译,通过!


image.png


第四步,运行项目,会在运行时报

dyld: Library not loaded: @rpath/JQTestTdb.framework/JQTestTdb

Reason: image not found

如下图:

image.png


第五步,我们将之前生成好的JQTestTdb.framework手动copy到/Users/{userName}/Library/Developer/Xcode/DerivedData/LoginApp-ejzarlssezrclpgjnslulafmqgpb/Build/Products/Debug-iphonesimulator/LoginApp.app/Frameworks目录下,这个目录怎么找?找到项目的Products,右键选中.app文件在Finder中显示,然后选中.app文件,显示包内容,就可以看到Frameworks文件夹了。(ps:当然这个也可以用脚本来copy,只要指定好相应的路径就可以了)


image.png


image.png



image.png

image.png


第六步,再次运行项目,通过!打印出JQTestTdbPerson的实例对象,结束!


image.png



相关文章
|
8月前
|
存储 Android开发 iOS开发
iOS不支持HEIC格式的图片显示和标签函数显示问题及解决方案
iOS不支持HEIC格式的图片显示和标签函数显示问题及解决方案
263 0
|
8月前
|
存储 Web App开发 Android开发
iOS不支持WebP格式图片解决方案和iPhone 7及其后硬件拍照的HEIC格式图片
iOS不支持WebP格式图片解决方案和iPhone 7及其后硬件拍照的HEIC格式图片
726 1
iOS不支持WebP格式图片解决方案和iPhone 7及其后硬件拍照的HEIC格式图片
|
8月前
|
Android开发
【苹果安卓通用】xlsx 和 vCard 文件转换器,txt转vCard文件格式,CSV转 vCard格式,如何批量号码导入手机通讯录,一篇文章说全
本文介绍了如何快速将批量号码导入手机通讯录,适用于企业客户管理、营销团队、活动组织、团队协作和新员工入职等场景。步骤包括:1) 下载软件,提供腾讯云盘和百度网盘链接;2) 打开软件,复制粘贴号码并进行加载预览和制作文件;3) 将制作好的文件通过QQ或微信发送至手机,然后按苹果、安卓或鸿蒙系统的指示导入。整个过程简便快捷,可在1分钟内完成。
180 6
|
8月前
如何下载网页中的视频成mp4格式
如何下载网页中的视频成mp4格式
|
数据安全/隐私保护
亲测可行!!!将下载好的优酷文件kux格式转为MP4格式
亲测可行!!!将下载好的优酷文件kux格式转为MP4格式
亲测可行!!!将下载好的优酷文件kux格式转为MP4格式
|
iOS开发
iOS formData形式上传身份证正反面图片到服务器
iOS formData形式上传身份证正反面图片到服务器
239 0
|
iOS开发
iOS下载文件保存到手机文件指定目录
iOS下载文件保存到手机文件指定目录
1171 0
|
iOS开发
iphone中获取文件路径的4种方法
iphone中获取文件路径的4种方法
431 0
|
XML Android开发 数据格式
【Android 安装包优化】7z 文件压缩格式 ( 7z 格式简介 | 7z 命令使用说明 )(二)
【Android 安装包优化】7z 文件压缩格式 ( 7z 格式简介 | 7z 命令使用说明 )(二)
799 0
【Android 安装包优化】7z 文件压缩格式 ( 7z 格式简介 | 7z 命令使用说明 )(二)
|
存储 算法 Android开发
【Android 安装包优化】7z 文件压缩格式 ( 7z 格式简介 | 7z 命令使用说明 )(一)
【Android 安装包优化】7z 文件压缩格式 ( 7z 格式简介 | 7z 命令使用说明 )(一)
426 0
【Android 安装包优化】7z 文件压缩格式 ( 7z 格式简介 | 7z 命令使用说明 )(一)