编译速度监测工具BuildTimeAnalyzer
随着swift项目业务代码不断增加,导致项目编译时间越来越长,通过网上查找阅读了几篇关于如何使编译速度提升的文章,现总结如下:
1.使用Optional进行拆包时,不可有多重拆包,例如:
let model = listModel.first
let params = ["test":model?.landName ?? "","hello":model?.statusName ?? "","id":model?.landId ?? "","transform":model?.oneCropId ?? ""]
其编译时间会增加很多,下面分别是写法一、写法二、写法三的编译时间对比,
⚠️不推荐写法一
data:image/s3,"s3://crabby-images/40792/407927274f6b0ddc2a4002b25f8b55f7b9091428" alt=""
推荐写法二
data:image/s3,"s3://crabby-images/6cb2c/6cb2c079759de4005212deffecb54054b489a25d" alt=""
2.使用??(nil-coalescing 空合并运算符) 及 ”+“拼接在一起的耗时,例如:
return CGSize(width: 10 + (view?.bounds.width ?? 0), height: (view?.bounds.height ?? 0) + 22)
⚠️不推荐写法一
data:image/s3,"s3://crabby-images/ed858/ed858a4247e024a924fd6cf95f1883c47e205768" alt=""
推荐写法二
data:image/s3,"s3://crabby-images/24ff3/24ff380b14ecfd8d032cee5cfcbeb96661e33ea1" alt=""
3.使用+或+=操作字符串拼接或数组拼接时耗时,例如:
let arr1 = [1,2,3]
let arr2 = [3,4,5]
result = arr1 + arr2 + [10]
⚠️不推荐写法一
data:image/s3,"s3://crabby-images/07e9e/07e9e6bb5923193b2d6c416b6fa8e804b9983ba4" alt=""
推荐写法二
data:image/s3,"s3://crabby-images/0ac0c/0ac0c1b2287a192c3acae83e8a7319289c0be680" alt=""
4.使用三元运算符与其他操作符结合或者高阶函数同时使用时耗时,例如:
data:image/s3,"s3://crabby-images/e883c/e883c761887b26892ab9dfd46bf2b25f66a5f00d" alt=""
5.一行代码使用过多的CGFloat转换同时再加上运算符使用时耗时,例如:
data:image/s3,"s3://crabby-images/943d3/943d3f25fe97cad01e6d242cb0733075b0e50a87" alt=""
6.另外有文章说使用lazy时耗时
参考文章如下:
网友评论