(WWDC) 良好的开发者习惯

本文围绕代码开发,介绍了组织、版本控制、注释与文档、测试、分析、评估、解耦和依赖管理等方面的要点。如组织工作空间可提升效率,推荐用 Git 进行版本控制,强调注释和文档的重要性,还提及测试保证代码质量等内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


内容概览

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




组织


混乱不堪井然有序
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




转载请注明出处,谢谢~

电动汽车数据集:2025年3K+记录 真实电动汽车数据:特斯拉、宝马、日产车型,含2025年电池规格和销售数据 关于数据集 电动汽车数据集 这个合成数据集包含许多品牌和年份的电动汽车和插电式车型的记录,捕捉技术规格、性能、定价、制造来源、销售和安全相关属性。每一行代表由vehicle_ID标识的唯一车辆列表。 关键特性 覆盖范围:全球制造商和车型组合,包括纯电动汽车和插电式混合动力汽车。 范围:电池化学成分、容量、续航里程、充电标准和速度、价格、产地、自主水平、排放、安全等级、销售和保修。 时间跨度:模型跨度多年(包括传统和即将推出的)。 数据质量说明: 某些行可能缺少某些字段(空白)。 几个分类字段包含不同的、特定于供应商的值(例如,Charging_Type、Battery_Type)。 各列中的单位混合在一起;注意kWh、km、hr、USD、g/km和额定值。 列 列类型描述示例 Vehicle_ID整数每个车辆记录的唯一标识符。1 制造商分类汽车品牌或OEM。特斯拉 型号类别特定型号名称/变体。型号Y 与记录关联的年份整数模型。2024 电池_类型分类使用的电池化学/技术。磷酸铁锂 Battery_Capacity_kWh浮充电池标称容量,单位为千瓦时。75.0 Range_km整数表示充满电后的行驶里程(公里)。505 充电类型主要充电接口或功能。CCS、NACS、CHAdeMO、DCFC、V2G、V2H、V2L Charge_Time_hr浮动充电的大致时间(小时),上下文因充电方法而异。7.5 价格_USD浮动参考车辆价格(美元).85000.00 颜色类别主要外观颜色或饰面。午夜黑 制造国_制造类别车辆制造/组装的国家。美国 Autonomous_Level浮点自动化能力级别(例如0-5),可能包括子级别的小
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值