iOS 静态库详解与开发

一:介绍

1. 什么是库?

库是共享程序代码的方式,一般分为静态库和动态库。

静态库:链接时完整地拷贝至可执行文件中,被多次使用就有多份冗余拷贝。

动态库:链接时不复制,程序运行时由系统动态加载到内存,供程序调用,系统只加载一次,多个程序共用,节省内存。

库.png

2. 两种形式中.framework的区别

如上图所示,静态库的形式包含.a和.framework两种形式,动态库的形式包含.dylib和.framework。
静态库和动态库都有.framework,但是各有所指,系统的.framework是动态库,我们自己建立的.framework是静态库。

3. 静态库中.a与.framework的区别

.a是一个纯二进制文件,.framework中除了有二进制文件之外还有资源文件。
.a文件不能直接使用,至少还有.h文件配合,.framework文件可以直接使用,因为本身包含了h文件和其他文件

4. 静态库的优点

  • 实现程序的模块化,将固定的业务模块化成静态库。
  • 方便共享代码,即可以和别人分享你的代码库,但别人又看不到你代码的实现。
  • 开发第三方sdk的需要,例如两个公司之间业务交流,不可能把源代码都发送给另一个公司,这时候将私密内容打包成静态库,别人只能调用接口,而不能知道其中实现的细节。

公司项目需要开发出一套同时支持微信支付、支付宝支付、银联支付的sdk,既要满足本公司项目需求,还需要提供给友方公司使用。

同时集成三家第三方的支付sdk,其中有大量的配置冲突需要解决。这篇文章通过demo和大家介绍一下如何开发自己的静态库.a文件,分享给大家,同时对工作进行总结。

二:静态库实现

1. 新建一个静态库工程

打开Xcode,点击File\New\Project,选择iOS\Framework & Library\Cocoa Touch Static Library新建一个静态库工程。

11.png

将工程命名为FBYSDKDemo,然后将工程保存到一个空目录下。
静态库工程由头文件FBYSDKDemo.h和实现文件FBYSDKDemo.m组成,这些文件将被编译为库本身,如下图:

22.png

在开发中,为了让开发的静态库使用起来更方便,只需要让使用者导入一个头文件,便可以访问你所提供的接口,并且通过接口进行数据回调。

2. 导入头文件

导入UIKit的头文件,这是创建一个库所需要的。当你在创建不同的组成类时,你将会为它们添加到这个文件中,确保它们能够被库的使用者获取到。

打开FBYSDKDemo.h,引入头文件

#import <UIKit/UIKit.h>

点击Build Phases,展开Link Binary with Libraries这一部分,点击+添加一个新的framework,找到UIKit.framework,点击add添加进来。

33.png

如果不结合头文件,静态库是没有用的,静态库编译一组文件,在这些文件中类和方法都以二进制数据的形式存在。
在静态库中类分为两类,一类是公开的public,一类是私有的只能内部访问使用。

接下来,需要在build栏中添加新的phase,来包含所有头文件。
在Xcode的Build Phases界面,选择Editor\Add Build Phase\Add Headers Build Phase。

注意:如果发现按上面找到的菜单项是不可点击的,如下图:

44.png

点击下方Build Phases界面的白色区域来获取Xcode的应用焦点,然后重新试一下

55.png

把FBYSDKDemo.h从项目中拖到Copy Headers下的Public部分。
这里是要保证用户可以使用库中公开的类或者接口。

66.png

Copy Headers下的Public部分中所添加的类均是对外公开的。
这里有三个分组,Public公开的,Private下的头文件是可以被用户看到的,Project下的文件是私有的,这里建议尽量将文件放在Public和Project下。

3. 添加配置

添加配置主要是在Build Settings下操作,点击项目名,然后选择FBYSDKDemo静态库目标,选择Build Setting栏,然后搜索public header,双击Public Headers Folder Path,在弹出视图中键入如下内容

include/$(PROJECT_NAME)

截图如下:

77.png

因为你创建好的静态文件供他人使用,最好禁掉无效代码和debug符号,让用户自己选择对自己的项目有利的部分使用。
在搜索框中分别搜索Dead Code Stripping、Strip Debug Symbol During Copy、Strip Style配置如下:

  • Dead Code Stripping设置为NO
  • Strip Debug Symbol During Copy 全部设置为NO
  • Strip Style设置为Non-Global Symbols

到目前为止,项目的构建已经完成,选择目标为Generic iOS Device,按下command + B进行编译,工程导航栏中Product目录下libRWUIControls.a文件将从红色变为黑色,表明现在该文件已经存在了。右键单击libRWUIControls.a,选择Show in Finder,如下图所示:

83.png

上图就可以看到对外公开的FBYSDKDemo.h类,其他实现类均以二进制的形式在libFBYSDKDemo.a中。

4. 功能实现

这里以实现静态库的开发为主,功能部分实现一个简单的功能demo来举例。

在头文件FBYSDKDemo.h中实现如下代码:

#import <UIKit/UIKit.h>
#import <Foundation/Foundation.h>

typedef void (^FBYSDKCompletion)(NSString *result);

@interface FBYSDKDemo : NSObject

/**
 *
 *  @param urltype       网页类型信息 urltype可为iOS、Android
 *  @param completion    根据urltype获取到相应网页url结果回调
 *
 */
- (void)urlType:(NSString *)urltype withCompletion:(FBYSDKCompletion)completion;

@end

其中urltype为网页类型信息 urltype可为iOS、Android,根据urltype获取到相应网页url结果回调completion。

在实现文件FBYSDKDemo.m中代码如下:

#import "FBYSDKDemo.h"

@interface FBYSDKDemo ()

@end
@implementation FBYSDKDemo

- (void)urlType:(NSString *)urltype withCompletion:(FBYSDKCompletion)completion{
    
    if ([urltype isEqualToString:[NSString stringWithFormat:@"iOS"]]) {
        
        if (completion) {
            completion(@"https://juejin.im/post/5a41c04c6fb9a044fc44fd23");
        }
        
    }else if ([urltype isEqualToString:[NSString stringWithFormat:@"Android"]]) {
        
        if (completion) {
            completion(@"https://juejin.im/post/5a31e6adf265da430c11d41f");
        }
        
    }
    
}
@end

选择目标为Generic iOS Device,按下command + B进行编译。

5. 合并静态库

选择目标为Generic iOS Device,编译运行后,右键单击libRWUIControls.a,选择Show in Finder显示的libFBYSDKDemo.a可在真机,如果在虚拟机中运行会报错。

所以还要选择目标为虚拟机(例如iPhone 7),然后编译运行,右键单击libRWUIControls.a,选择Show in Finder显示的libFBYSDKDemo.a可在虚拟机中运行,如果在真机中运行会报错。

85.png

合并方法:打开终端,输入 lipo -create 真机库.a的路径 模拟器库.a的路径 -output 合成库的名字(可以复制模库.a的路径,修改名字).a;回车就可以在模拟库的文件夹中看到新合成的.a文件了,如下图:

87.png

合成后静态库文件截图如下:

86.png

libFBYSDKDemo_all.a文件即为静态库文件,一个通用的静态库.a就做好了。

三:静态库使用

1. 导入静态库

导入静态库和.h头文件,注意下图选项:

89.png

2. 调用函数

源码如下:

- (void)blogsBtn:(UIButton *)sender {
    
    if (sender.tag == 6000) {
        
        [FBYSDKDemo urlType:@"iOS" withCompletion:^(NSString *result) {
            
            [self contentURL:result];
            
        }];
    }else if (sender.tag == 6001) {
        
        [FBYSDKDemo urlType:@"Android" withCompletion:^(NSString *result) {
            
            [self contentURL:result];
        }];
    }
}

result就是通过sdk回调获取到的结果。

3. DEMO截图如下

DEMO截图

希望可以帮助大家
如果哪里有什么不对或者不足的地方,还望读者多多提意见或建议
如需转载请联系我,经过授权方可转载,谢谢

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,736评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,167评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,442评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,902评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,302评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,573评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,847评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,562评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,260评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,531评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,021评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,367评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,016评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,068评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,827评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,610评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,514评论 2 269

推荐阅读更多精彩内容