`

[转]静态类库(Static Library)详细教程

 
阅读更多

使用静态类库的好处:
    加快编译速度。如果类文件多了,在编译的时候,特别是重新清除完Target之后,会特别慢。如果把某些不需要经常改动,但又很必须的类单独拿出来编译成静态类库,整个项目的编译速度将会大大提高。
    方便代码共享。有些代码,不方便开源给别人,但又要提供给别人使用。比如,两个公司之间的合作。


制作静态类库: 
    为方便讲解,更方便与初期代码测试,新建一个项目,StaticLibraryExample

    新建Target。 假设我们需要制作的静态类库名为 IMIBase. 右击Targets,添加新Target。选择Static Library, 名字为IMIBase

 


    添加类文件到IMIBase。在新建文件选项中注意,添加到的Target是IMIBase,而不是默认的StaticLibraryExample。

 

     随便写一个方法printAAA 打印字符串AAA。

 


    测试。双击Target StaticLibraryExample,在General中添加直接依赖关系,选择IMIBase。这样做的目的是保证每次运行测试的时候都会编译 IMIBase。 完成后command+b 编译。我们会在Products智能文件夹发现2个产品,一个是StaticLibraryExample.app 另一个是libIMIBase.a 后者就是我们需要的静态类库了,默认前缀是lib 后缀是.a的文件。(需要注意的是.a文件会被svn默认忽略掉,请google svn配制)。将.a文件拖到Target StaticLibraryExample的Link Binary With Libraries文件夹。  

 


    在AppDelegate中使用我们刚才建的类。
#import "IMIBaseNSStringHelper.h" 
[IMIBaseNSStringHelper printAAA ]; 

    运行,恭喜,看到AAA在调试终端上打印出来了!
          

 


    输出产品。现在.a文件已经就是我们需要的了,我们可以把这个文件拷贝出来用了。需要注意的是:1 头文件,也要拷贝出来。2 现在的类库只能在模拟器上用,我们还需要编译一遍为真机使用。

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics