详解swift中xcworkspace多项目管理

时间:2022-09-20 17:48:15

给大家详细简介了xcworkspace多项目管理的设置方法,一起来学习下。

技术说明:

今天在这里分享 swift下的 xcworkspace多项目管理(架构思想),能为我们在开发中带来哪些便捷?能为我们对整个工程的维护,整理,模块解偶带来哪些优势?以及在swift与OC下的混编开发中的调用会遇到哪些问题?

带着问题探研:

(1).xcworkspace工程怎么创建?工程framework如何创建?主工程项目如何创建?

(2).主工程调用子工程framework如果配置?

(3).framework与framework之间如何调用?

(4).xcworkspace工程Pods的集成,framework的Pods第三的集成?

(5).Podfile文件的编辑,以及对应主工程,对应framework的编写方式?

--------------历史分析-----------------------

你还在搭建这样的框架吗?

详解swift中xcworkspace多项目管理

缺点:

这种方式搭建的项目会随着项目功能不断的强大,从而会使模块文件越来越庞大,也会使项目维护思维近近模糊,

业务层代码与数据层代码和项目核心层代码相互交织,无法拆分,不符合一个中上等级以及长远发展公司型的构架思想!

来看下大公司项目的搭建吧:

详解swift中xcworkspace多项目管理

优点很明确,个个模块可以拆分,架构思想清晰明朗,业务层独立清晰没有耦合

--------------xcworkspace项目创建--------------

File -> New -> Workspace

--------------子工程framework创建 (注意:新建主工程,不要创建成framework)

1 :File -> New -> Project -> framework (创建的是静态库)

详解swift中xcworkspace多项目管理

 

2 :修改添加目标到workspace:(就是上一步创建的Workspace工程)

 详解swift中xcworkspace多项目管理

 

--------------主工程调用子工程framework相关配置--------------

第一:子工程暴露文件出来:必须顺序执行

BuildPhases -> Headers -> Public(只有放入共有栏,才能调用)->  导入项目代码文件(一般默认放在Project中)

BuildPhases -> Headers -> Public ->  中导入需要暴露给的OC 的头文件 (一般默认实现)

(注意:只有混编的时候才需要导入,也就是没有混编,framework中的.h文件可以删除)

BuildPhases -> Compile Sources ->  中导入项目代码文件

第二:把需要提供外部调用的类,属性和方法,加public修饰(swift) 

第三:  编译(⌘+B)一下工程,生成framework(重要,配置如果改动,删除对应生成的framework,重新编译生成)

——————分别—真机编译:

详解swift中xcworkspace多项目管理

——————分别—模拟器编译:

详解swift中xcworkspace多项目管理

Show  In  Finder ,确认生成framework

详解swift中xcworkspace多项目管理

 

第四:主项目导入framework

把生成的framework拖入主项目中(这样做比较好),

———————不建议以下做法————————

//选择主项目 ->  General ->  Embedded Binaries -> 选择framework导入

(Embedded Binaries导入,会同步Linked Frameworks and Librares导入)

 第五:在需要调用framework   ipa 的文件中  import 相关framework的工程名,即头文件,完成

------------------- framework之间相互调用 ipa --------------

General —>   Linked Frameworks and Libraries —> 导入指定framework

********到这里framework与主项目之间的调用已经完成,可以实现了!

--------------------Pods的集成------------------

第一:创建的主项目,创建的多静态库(注意必须在同一级目录下)

详解swift中xcworkspace多项目管理

 

第二:终端cd 项目跟目录:

详解swift中xcworkspace多项目管理

 

第三:终端指令:touch Podfile   (此处为空太),创建Podfile文件

第四:Podfile文件的编辑

案列:-------

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
platform :ios, ‘8.0' ———可以写在最上面,标示公用
 
use_frameworks!  ———用cocoapods导入OC框架到swift项目必须写
 
workspace 'MyWorkspace.xcworkspace' //workspace文件名
 
project 'MyApp2/MyApp2.xcodeproj' //主工程路径„
 
  target 'MyApp2' do
 
  project 'MyApp2/MyApp2.xcodeproj' //工程路径
 
  pod 'Masonry', '~> 1.0.2'
 
end
 
  target 'MyApp1' do 
 
   project 'MyApp1/MyApp1.xcodeproj' //framework
 
   pod 'SnapKit', '~> 1.0.2'
 
   pod 'SDWebImage', '~> 1.0.2'
 
end

 

第五:终端下载指令 pod install

第六:framework调用第三方框架

查看项目:未导入,项目无法调用

详解swift中xcworkspace多项目管理

导入查看项目:项目同步

详解swift中xcworkspace多项目管理

 

 注意:swift 版的framework调用OC写的第3方,必须在.h 里面声明头文件,才能调用

详解swift中xcworkspace多项目管理

 

----------------补充 : 静态库与动态库的区别

 静态库有 .a 和 .framework

动态库有.dylib 和 .framework

后来.dylib动态库又被苹果替换成.tbd的形式

静态库和动态库是相对编译期和运行期的:

1.静态库在程序编译时会被链接到目标代码中,程序运行时将不再需要改静态库

2.动态库在程序编译时并不会被链接到目标代码中,只是在程序运行时才被载入,因为在程序运行期间还需要动态库的存在

总结:

同一个静态库在不同程序中使用时,每一个程序中都得导入一次,打包时也被打包进去,形成一个程序。

而动态库在不同程序中,打包时并没有被打包进去,只在程序运行使用时,才链接载入(如系统的框架如UIKit、Foundation等),所以程序体积会小很多,但是苹果不让使用自己的动态库,否则审核就无法通过。

原文链接:https://www.cnblogs.com/tangjianfeng/p/7898903.html