(WWDC) 良好的开发者习惯


内容概览

  • 组织
  • 版本控制
  • 注释 & 文档
  • 测试
  • 分析
  • 评估
  • 解耦
  • 依赖管理




组织


混乱不堪井然有序
1306450-3e0f036d355bddf6.png
1306450-0606734981d5d60e.png

组织有序的工作空间可以大幅度提升你的工作效率!



Xcode Group 和 Finder Folder 一一对应:

1306450-810d385c47572d96.png


利用 Storyboard 的 Reference 功能,合理划分不同模块的 Storyboard:

1306450-2bff1c56474c22a1.png

更新项目设置为 Xcode 推荐的配置:

1306450-92a63ad3f703fe16.png

使用最新的构建系统:

1306450-af941deefc0fb473.png


总结
  • 根据功能来进行模块划分
  • 使项目的组织结构和文件的组织结构相同
  • 拆分庞杂的 storyboard
  • 持续更新项目文件
  • 抛弃无用的代码片段 (版本控制系统可以很容易找回)
  • 解决导致警告的根本问题




版本控制


推荐使用 Git 进行版本控制:

1306450-685e27d7e1af2634.png

你可以很方便地对工作成果进行整合:

1306450-affdb60e88ee5c0c.png


总结
  • 使用版本控制系统
  • 尽可能地使提交内容精简、独立
  • 添加有用的提交信息,便于以后查找
  • 利用分支进行调试和测试工作




注释 & 文档


维护没有文档的代码时,你总是要去熟悉已有代码的实现,然后在脑海中构建起上下文。
如果上下文的跨度比较广时,文档是必不可少的。


使用描述性的名称对变量、方法进行命名,使用注释进行合理的解释:

1306450-a7a9c9ff71b34ddb.png

详尽的文档可以帮助使用者快速地了解代码的用法以及注意事项:

1306450-134a72d3fab1e1d3.png

按下快捷键,快速地为代码添加文档注释:

1306450-e8f2e9e37929a750.png

按住 Option 然后点击鼠标左键,即可查看代码的文档:

1306450-2da15375ec09cc14.png
总结
  • 注释对于以后理解代码至关重要
  • 好的注释可以提供背景和推理
  • 使用描述性的变量、常量名称
  • 使用文档




测试


测试(常见的是单元测试)可以有效地保证代码的质量。
编写测试代码时,你需要关注测试的覆盖率。

可靠的测试可以保证重构时的自信!你会对这样的测试心存感激!


总结
  • 写单元测试
  • 每次提交代码前,运行单元测试
  • 为持续集成构建基础




分析


制造弱网络环境,模拟真实的使用场景:

1306450-6bbc2ac9a349e416.png

使用 Address Sanitizer (内存错误问题), Thread Sanitizer(线程竞态等问题), Undefined Behavior Sanitizer(0做除数等问题), Main Thread Checker(非主线程操作UI) 检查运行时可能出现的诸多问题:

1306450-976e2e1ea8f6565a.png

Debug 导航器页面可以查看 CPU, 内存, 磁盘, 网络相关的信息:

1306450-5b37d209a4ea9d29.png

使用 Instruments 进行问题剖析,比如使用 Time Profiler 检查耗时操作:

1306450-b646491a2357c32c.png


总结
  • 使用 Network Link Conditioner 模拟弱网络环境
  • 使用 Sanitizers 和 Checkers 监测运行时故障
  • 使用 Debug 导航器页面的工具测量性能和能耗
  • 使用 Instruments 探查问题成因




评估


Code Review 可以帮助你改善代码质量。

在进行 Code Review 时,你需要理解每一处改动,然后构建代码并验证测试能否成功通过。
还需要对代码进行校对,比如:命名规范等。

不同的团队有不同的代码风格和规范,比如:color 和 colour 的小小差别,就会使搜索结果相差甚远。

如果你是独立开发者,建议你参与社区协作开发(开源库)或者寻找你的伙伴!

1306450-5219c65d7e5f019b.png


总结
  • 在你的开发实践中加入 Code Review
  • 理解每一行代码
  • 构建并运行代码
  • 为代码运行测试
  • 校对代码风格、拼写以及语法




解耦


使用 Swift Package Manager 进行代码库管理。

你可以在常见的代码仓库平台找到开源库,也可以在这些地方发布你自己的代码库:

1306450-58a7efe1a4055e21.png

代码库需要提供必要的文档:

1306450-ec8ba9d046ea7d4c.png


总结
  • 判定功能分割部分,然后拆分
  • 跨多个应用程序扩展你的劳动成果
  • 通过 extension 提升效率
  • 和广阔的社区共享你的劳动成果
  • 文档是必不可少的




依赖管理


1306450-c4607a068b326998.png
  • 合理地使用社区和开源项目
  • 彻底地理解依赖
  • 确保尊重隐私权
  • 做好计划,以防代码库消失或者不再维护





参考内容:
Great Developer Habits




转载请注明出处,谢谢~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值