iOS -- 代码优化

embedded/2024/10/23 18:27:10/

目录

  • 1. filter 优化
  • 2. return 优化
    • 案例1
    • 案例2
  • 3. for循环优化
    • 案例1
    • 案例2
  • 4. 枚举 优化
  • 5. 未完待续……

1. filter 优化

原代码

 if var vcs = vcs {for vc in vcs {if vc is XXLoginViewController {if let index = vcs.firstIndex(of: vc) {vcs.remove(at: index)}}
}

修改后

vcs = vcs?.filter { !($0 is XXLoginViewController) }

或者

vcs?.removeAll(where: { $0 is XXLoginViewController })

filter, map, reduce的用法详见
https://juejin.cn/post/6844903574506307592
https://www.jianshu.com/p/74854e641d87

2. return 优化

案例1

func checkExpire(time: TimeInterval) -> Bool {if Date().timeIntervalSince1970 - time > 0 {return false}return true
}

优化后

func checkExpire(time: TimeInterval) -> Bool {return Date().timeIntervalSince1970 < time
}

是不是更简洁了呢!

案例2

if (isInCache) {return result;
} else {return [DataXXManager.shareManager isStickUpWithXxId:xxId];
}

可以通过移除不必要的else语句来优化代码,因为在if条件满足时,return会直接返回,后续代码不会执行。以下是优化后的代码:

优化后

if (isInCache) {return result;
}
return [DataXXManager.shareManager isStickUpWithXxId:xxId];

3. for循环优化

案例1

for index in 0..<array.count {guard let item = array[index] as? XXX else {continue}// do other
}

优化后

for (index, header) in array.enumerated() {guard let item = header as? XXX else {continue}// do other
}

案例2

优化前

var index = 0
var tempItems: [[ObjectProtocol]] = [ObjectProtocol]
for item in self.items {if index >= 3 {break}if let f = self.items.last as? [ObjectProtocol] {tempItems.append(f)}index += 1
}
self.items = tempItems

优化后

var tempItems: [[ObjectProtocol]] = []for item in self.items.prefix(3) {if let f = item as? [ObjectProtocol] {tempItems.append(f)}
}self.items = tempItems

4. 枚举 优化

例如有如下的需求,像数据库中添加obj字段,obj的order字段如果是auto,则根据head和tail字段来表示自动变化order,如果非auto,则使用obj自己的order字段 内容。
直观的代码如下:

- (void)addSomethingToDB(NSObject *)obj auto:(BOOL)auto isAddToHead:(BOOL)head isAddToTail:(BOOL)tail {if (auto) {if (head) {obj.order = --index} else if (tail) {obj.order = ++index}}
}

上面的代码,用了auto, head和tail来表示,添加的顺序。是不是繁琐。那怎么简化呢?
可以用枚举来优化。

typedef NS_ENUM(NSInteger, XXSortOrder) {XXSortOrderNo, // 不自动排序XXSortOrderAddToHead, // 自动排序,在头插入XXSortOrderAddTail, // 自动排序,在尾插入
}- (void)addSomethingToDB(NSObject *)obj sortType:(XXSortOrder)sortType {if (XXSortOrder == XXSortOrderAddToHead) {obj.order = --index} else if (XXSortOrder == XXSortOrderAddToHead) {obj.order = ++index}
}

这么写,是不是从方法名和函数内容都精简了不少呢?哈。

5. 未完待续……


http://www.ppmy.cn/embedded/129872.html

相关文章

软考-软件设计师-简答(2)-数据库设计基础-知识点、题型、技巧、历年真题解析

场景 软考-软件设计师-选择题高频考点整理。 以下为高频考点、知识点汇总。 软件设计师上午选择题知识点、高频考点、口诀记忆技巧、经典题型汇总: 软考-软件设计师(1)-计算机基础知识点:进制转换、数据编码、内存编址、串并联可靠性、海明校验码、吞吐率、多媒体等: 软…

挑战性课程《信号处理系统》(原信号与系统+数字信号处理)课程课程设计

挑战性课程《信号处理系统》&#xff08;原信号与系统数字信号处理&#xff09;课程课程设计 课程设计题目4&#xff1a;图像处理 课程设计基本要求 基于DCT的图像压缩另一种图像压缩算法并实现额外的两个功能 实际实现的功能 基于DCT的图像压缩以及MSE的计算基于奇异值分…

力扣10.21

474. 一和零 给你一个二进制字符串数组 strs 和两个整数 m 和 n 。 请你找出并返回 strs 的最大子集的长度&#xff0c;该子集中 最多 有 m 个 0 和 n 个 1 。 如果 x 的所有元素也是 y 的元素&#xff0c;集合 x 是集合 y 的 子集 。 数据范围 1 < strs.length < 6…

『完整代码』坐骑召唤

创建一个按钮 作为召唤/消失坐骑的开关 将预制体放入指定文件夹 命名为Mount01 创建脚本并编写&#xff1a;CallMount.cs using UnityEngine; using UnityEngine.UI; public class CallMount : MonoBehaviour{public Button callBtn;GameObject mountPrefab;GameObject mountIn…

安装vue发生异常: idealTree:nodejs: sill idealTree buildDeps

一、异常 C:\>npm install vue -g npm ERR! code CERT_HAS_EXPIRED npm ERR! errno CERT_HAS_EXPIREDnpm ERR! request to https://registry.npm.taobao.org/vue failed, reason: certificate has expired 二、原因 请求 https://registry.npm.taobao.org 失败&#xff0c;证…

DAB-DETR: DYNAMIC ANCHOR BOXES ARE BETTER QUERIES FOR DETR论文笔记

原文链接 [2201.12329] DAB-DETR: Dynamic Anchor Boxes are Better Queries for DETR (arxiv.org)https://arxiv.org/abs/2201.12329 原文笔记 在本文中&#xff0c;我们提出了一种新的查询公式&#xff0c;使用动态锚框进行DETR (DEtection TRansformer)&#xff0c;并对查…

【linux】GCC 7和GCC 8版本不再包含在默认的软件仓库中

由于GCC 7和GCC 8版本不再包含在默认的软件仓库中&#xff0c;不能直接通过apt install gcc-7或apt install gcc-8命令来安装这些版本。不过&#xff0c;可以通过添加Ubuntu 20.04&#xff08;Focal Fossa&#xff09;的软件仓库到系统来安装这些较旧的GCC版本&#xff0c;因为…

简单介绍冯诺依曼体系

现代的计算机, 大多遵守冯诺依曼体系结构 CPU中央处理器&#xff1a;进行算术运算和逻辑判断。存储器&#xff1a;分为外存和内存&#xff0c;用于存储数据&#xff08;使用二进制方式存储&#xff09;。输入设备&#xff1a;用户给计算机发号施令。输出设备&#xff1a;计算机…