详解swift中xcworkspace多项目管理

时间:2021-05-02

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

技术说明:

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

带着问题探研:

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

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

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

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

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

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

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

缺点:

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

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

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

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

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

File -> New -> Workspace

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

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

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

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

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

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

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

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

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

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

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

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

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

Show In Finder ,确认生成framework

第四:主项目导入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的集成------------------

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

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

第三:终端指令: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 版的framework调用OC写的第3方,必须在.h 里面声明头文件,才能调用

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

静态库有 .a 和 .framework

动态库有.dylib 和 .framework

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

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

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

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

总结:

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

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

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

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章