从http://www.cocoachina.com/ios/20150828/13170.html转载,谢谢写这篇文章的大神!
标题有些吓人请不要害怕,不过这确实不是扫盲贴,需要一定的iOS开发基础。在我多年的码农生涯中绝大部分时间都是做的小项目,大一些的可能也就是百万行代码的样子,跟Windows系统几千万行源码比简直就是小巫见大巫。不过,一个iOS项目的源码有数百万行算蛮大了。我想说的是,人总是会成长,会担当更大的责任接受更大的挑战,终有一天组织会有重要任务交给你。不过软件开发不是一朝一夕,也不会有多么的轰轰烈烈,更多的是平淡中无数的细节处理。做大型项目未必就需要多么高深的技术,也许就是细节的科学处理与规范的管理。

首先说说编程语言的选择,Objecive-C还是Swift?我还没有在项目中使用Swift,因为我说服不了自己去用它,它的优势在哪里,你也不能强迫队友去学习Swift。当然,不用不代表不会,一入行就用Swift开发无意义产品的人没资格戴着有色眼镜鄙视不会Swift的同行。你知道Objecive-C与Swift混编有多少坑吗?你知道Swift也是跟Objecive-C共用一个Runtime环境吗?你知道使用了Swift会使得ipa包大10多M吗?Swift代表未来,Objecive-C是当下。Swift能做的Objective-C都能做,比如Closure完全就可用Blocks来代替,Tuple完全可以用结构体来代替。生产环境用Objective-C,业余观望Swift,这就是我的态度。Raywenderlich已经出了一堆Swift的教程,在前沿科技的使用上国内总是慢一个节拍,很大程度上那堵墙阻碍了国内IT从业者的发展,墙的开发者(包括我的信息安全工程老师)终有一天会受到历史的审判。

再来说说应用架构,真是成也MVC,败也MVC。如果放任团队中的小朋友按他们所理解的MVC来开发,一般情况下出现的恶果就是类之间高耦合,Controller胖得不像话简直就成了百宝箱……每一次的版本迭代都会痛苦不堪,若功能不多还能勉强维持功能多了势必崩塌,就比如世博园中国馆吧,再按比例多盖5层试试看,呵呵。到头来开发人员实在受不了就只能选择重构要么跑路,后者更现实大家都懂,尤其是业务为王的企业里,代码质量算个屁只要能work,可是好的程序员都是有尊严的,deadline或是拍脑袋的政治任务通常会让程序员疲于应付,厌倦了也就该撤了。言归正传,既然MVC显得臃肿,那就是瘦身呗。通常瘦身后的MVC在iOS界被叫成MVCS或MVVM,这2个当然不是同一个东西,项目选用MVCS还是MVVM还是得看你的业务特性。MVCS与MVVM就那么完美吗?当然不,MVCS要注意Service/Store的滥用,其中的数据是否会被不同的模块污染。MVVM用得不好也会增加项目的维护难度,我说的是View和ViewModel之间松散的绑定关系,在iOS开发中一提到MVVM大家就想到ReactiveCocoa,其实没有ReactiveCocoa也可以啊,只是ReactiveCocoa的好处多多,如代码收敛不必写得到处都是,其他好处自己去挖掘吧。

关于工程文件组织结构,很多人是Controllers/Views/Models/Vender…这样归类,其实这有个问题,比如你要找ControllerA的TableView用到的cellB类,你还要去Views里面一个个找,太痛苦了,就算search也还是苦毕竟不能所见即所得。我一般是按 Module来划分,每个Module里面有Controllers/Views/Models/Stores/API这样的分类,API是每一个接口的请求的封装,供Store调用,得到的数据解析实例化为Model再通过block传递给Controller去刷新View,很绕吗?使用RAC,Controller订阅Store里创建的RACSignal也能做到,U can make a try。还有就是Helper与Utility,与业务无关,具有对象性质,提供支持功能的代码放到Helper,比如创建一个自定义对象的封装。如果只是属于函数或算法,不是对象而且很多地方能用到,就放到Utility,比如排序/加密算法。

工程文件组织结构

关于网络通信模块的设计,我个人认为应该是每一个HTTP请求都应该独立互不干扰,就是你封装的POST/GET方法都会创建一个临时的对象,而长连接一般只维持一个实例对象采用单例的方式创建。我会为每一个HTTP 接口请求创建一个API对象,在里面请求数据,当然了为了避免请求代码的重复编写可以建立一个BASE API类,子类调用父类的请求方法就行了,不同的只是接口与参数。思想就是这样,以后有时间再来讲讲API类的设计。

关于多线程,在iOS开发中用得最多的就是GCD和NSOperation了,在大部分情况下GCD就够用了。但是NSOperation也有它的优势,比如可以设置并发个数,可以设置线程间的依赖,可以暂停和恢复,比较灵活,多线程下载就经常用它。面试中也经常会问GCD与NSOperation的区别,这个自己去查查,资料还是比较丰富的,底下也有篇关于NSOperation的参考链接。GCD虽然强大,可是还是有很多人瞎用,真替他们着急,随便说几点:

1.滥用dispatch_after做定时器导致crash!不知道还有个东西叫dispatch_source_set_timer吗?

倒计时

2.不要轻易用dispatch_sync,线程同步方法那么多为何你偏偏要爱上不该爱的它!尤其不要在dispatch_async里面用dispatch_sync,不要问为什么,百度里面google一下!

3.dispatch_once也就创建单例的时候用用,不要瞎用。dispatch_once是整个app生命周期内只执行一次,不是对象生命周期内只执行一次,大哥!

4.什么!你居然不知道用GCD创建串行线程与并行线程!

串行

并行

关于多团队协作,如果项目用分模块的方式进行开发,CocoaPods无疑是个非常好的工具。相对独立的模块尽量打成私有pod,这样,公共平台把整个项目的框架打好,其他的业务部门只需要自己建立一个私有pod,使用公共平台打好的那些私有pod独立开发调试就好,而不必时时提交代码到主工程,这样的话会非常麻烦,比如代码merge冲突,证书冲突,会疯掉的。当模块开发完毕再提交到主工程就好了。当然私有pod打多了也麻烦,私有pod依赖更多的私有pod在添加文件到target的时候会很痛苦,Xcode默认是target全部选上的,要跟Apple反馈一下希望他们会解决。

关于数据持久化,最重要的就是保持数据源的一致。还有一个比较重要的就是APP升级之后的向前兼容,那种你一升级app启动崩溃的问题,多半是新版本的数据结构发生变化,不支持老版本产生的数据或者设置等。我一直偏爱sqlite,用得最多的就是FMDB,对CoreData无爱。要知道苹果自己的app NEWS用的就是FMDB啊,我还记得有人问facebook的工程师“为啥你们的app速度慢呢”,“because we use core data!”。有个开源库MagicRecord,对CoreData的深度封装,我用过,其实也还不错。

另外,单元测试真的有必要吗?单元测试可以使逻辑清晰化,当你仅仅阅读单元测试代码的话,你会发现它们写的好像编程教科书里的伪代码。当TDD的时候,这一点尤其有用。通过写单元测试,你可以很快的把逻辑梳理清楚,然后用代码来实现它。单元测试可以降低代码的耦合度。我们知道,耦合度高的代码很难做单元测试,反过来,如果你必须做单元测试,你是不会把代码写的耦合度很高的。单元测试可以让你知道你对代码的修改是否影响到了原来就有的功能,但是这也是所有的回归测试都可以做的。单元测试的特点在于:它测试的东西足够小从而在代码重构后仍能复用。单元测试是唯一一个可能使覆盖率达到100%的测试。单元测试开始难,持续做的话会越来越容易,因为难主要是因为环境的搭建和桩函数的缺失。单元测试很容易定位Bug,它好像在你的程序中打了无数的断点。单元测试很费时间,不过,后续改Bug更费时间。

讲了这么多,最后说说需求吧。我认为在需求评审时应该尽量抛出细节问题给pm,他们不懂技术,如果需求不确定就盲目开发,然后中途再改需求,这是很伤士气的,尤其是涉及到架构的修改,这让我想到那张pm改需求被程序员拍板砖的图,嘿!需求不稳定,就别动工,宁愿打酱油看博客。好了,啰嗦了这么多,有多少人会看到这里呢?希望以后有空回头来增加些内容。

iOS 大型项目开发漫谈相关推荐

  1. iOS大型项目开发漫谈

    标题有些吓人请不要害怕,不过这确实不是扫盲贴,需要一定的iOS开发基础.在我多年的码农生涯中绝大部分时间都是做的小项目,大一些的可能也就是百万行代码的样子,跟Windows系统几千万行源码比简直就是小 ...

  2. iOS大型项目开发架构

    http://www.jianshu.com/p/921ab32c3c71# 首先说说编程语言的选择,Objecive-C还是Swift?我还没有在项目中使用Swift,因为我说服不了自己去用它,它的 ...

  3. iOS大型项目解耦方案有难度?BeeHive设计优化来帮助

    [https://yq.aliyun.com/articles/71685?utm_campaign=wenzhang&utm_medium=article&utm_source=QQ ...

  4. 大型项目开发,你准备好了吗?

    大型项目开发,你准备好了吗? 大型项目开发,你准备好了吗?----网站开发人员应该知道的62件事,今天在chinaz上看到的,写的很全面,也很到位,这些问题若是都解决了,网站开发可谓完美... 一.界 ...

  5. iOS大型项目之模块化管理

    2019独角兽企业重金招聘Python工程师标准>>> iOS大型项目之模块化管理 待写 转载于:https://my.oschina.net/zhuzhu1223/blog/157 ...

  6. python赚钱项目开发大体流程咨询_大型项目开发的基本流程

    万科四季花简介 万科四季花城总占地面积 217498.1 平方米 , 总建筑面积 407479 平方米 , 规划设计在万科城市 花园的基础上加以发展和延伸. 整个社区由多个围合式布局的小组团构成, 每 ...

  7. 【工具】PlatformIO终于能用了,arduino大型项目开发环境PIO,编辑器+编译器+调试全功能...

    微信关注 "DLGG创客DIY" 设为"星标",重磅干货,第一时间送达. 经过漫长的等待PlatformIO终于能用了,今天来聊聊这货. 这货张什么样子? 下图 ...

  8. arduino安装包_【工具】PlatformIO终于能用了,arduino大型项目开发环境PIO,编辑器+编译器+调试全功能...

    微信关注 " DLGG创客DIY "设为" 星标",重磅干货,第一时间送达. 经过漫长的等待PlatformIO终于能用了,今天来聊聊这货. 这货张什么样子? ...

  9. python大型项目开发规范_大型项目CMakeLIsts.txt的编写规范

    1.Very simple executable PROJECT( helloworld )   # 非必需 SET( hello_SRCS hello.cpp ) ADD_EXECUTABLE( h ...

最新文章

  1. DeepWide推荐系统
  2. 研发流程与项目管理之关系
  3. 系统中已安装了vmware,请先卸载干净并重启电脑
  4. 做了44年保洁员,一生只会5个字,她却成为香港大学院士
  5. HTML+CSS+JS 表白代码
  6. ubuntu ssh密钥_生成SSH密钥以在Ubuntu中进行无密码登录
  7. win7科学计算机不支持,win7“不支持的硬件,你的电脑使用的处理器专为最新版win...
  8. 常用DOS命令参数的中文详解3
  9. 小学文凭宝妈在家开网店?其实做跨境并不难!
  10. 坐标系统和投影变换基础知识及其在ArcGIS桌面产品中的应用(二)
  11. 生物科学与计算机科学计算案例,北京林业大学计算生物学与生物信息学考研经验-生物科学技术辅导...
  12. 微信小程序 - 音乐列表点击播放 / 暂停音频,流畅切换音频(支持暂停音乐后,保留音乐 “进度“ 继续播放)最好用最详细的源码示例教程,适用于wechat列表点击后播放 mp3 wav 文件的需求
  13. 设计模式看这篇就够了
  14. 2009年具有高等学历教育招生资格普通本科高职院校名单
  15. nextcloud服务器配置文档,NextCloud挂载数据盘
  16. 关于小间距QFN封装PCB设计的串扰抑制分析
  17. 计算机8字少一竖是什么符号,一长一短两竖符号怎么弄
  18. csrf漏洞防御方案_绕过CSRF防御
  19. 数据自动录入并生成报表神器怎么玩?
  20. Python-国内华为云下载一览表

热门文章

  1. 学会这样用PPT,你也可以靠副业实现财富自由!
  2. 基于JAVA旅行指南网站计算机毕业设计源码+系统+mysql数据库+lw文档+部署
  3. 计算机毕业设计JavaVue垃圾分类指南平台设计与实现(源码+系统+mysql数据库+lw文档)
  4. Unity3d学习笔记 var 关键字
  5. mac出现文件夹问号_Macbook文件夹怎么设置隐藏或显示?开机带问号的文件夹怎么办?...
  6. 【仓储管理系统需求分析(四)】
  7. python 使用node_vm2执行js
  8. 写出Java的第一个程序
  9. 使用ElasticSearch进行可扩展搜索
  10. Tomcat启动一闪而过就消失的原因和解决方法