Swift 核心技术与实战
张杰
美团点评高级技术专家
20981 人已学习
新⼈⾸单¥59
课程目录
已完结/共 120 讲
第十三章:Swift和Objective-C混合编程 (4讲)
Swift 核心技术与实战
登录|注册
留言
12
收藏
沉浸
阅读
分享
手机端
回顶部
当前播放: 56 | 函数式编程(1)
00:00 / 00:00
高清
  • 高清
1.0x
  • 2.0x
  • 1.5x
  • 1.25x
  • 1.0x
  • 0.75x
  • 0.5x
网页全屏
全屏
00:00
付费课程,可试看
01 | 课程介绍
02 | 内容综述
03 | Swift版本历史和各版本特性快览
04 | Swift和Objective-C的主要区别
05 | swiftc:强大的命令行工具
06 | REPL:Swift交互式解释器
07 | Playground:Swift学习的乐园
08 | 如何在Swift中定义常量和变量
09 | Swift中的数值类型
10 | 如何使用Tuple组合多个值
11 | 如何在Swift中使用Optional
12 | Optional实现原理探究
13 | 如何在Swift中创建和初始化字符串
14 | Swift字符串的常见操作
15 | 如何使用索引访问和修改字符串
16 | 如何在Swift中获取子串和进行字符串比较
17 | 赋值和算数运算符
18 | 在Swift里如何处理算术结果溢出
19 | 为了Optional:合并空值运算符
20 | Swift的新宠:区间运算符
21 | 强大的位运算符
22 | 位运算符应用举例(1)
23 | 位运算符应用举例(2)
24 | 运算符优先级和结合性
25 | 如何为类和结构体自定义运算符实现
26 | 如在Swift中定义自己的运算符
27 | 如何在Swift里进行循环控制
28 | 更加强大的switch
29 | 如何在Swift里进行控制转移
30 | 如何使用guard来改善你的条件判断
31 | Swift中的模式和模式匹配
32 | 在Swift中创建数组的N种方式
33 | 访问和操作数组:遍历和索引
34 | 访问和操作数组:查找操作
35 | 访问和操作数组:添加和删除
36 | 访问和操作数组:ArraySlice
37 | 访问和操作数组:重排操作
38丨访问和操作数组:拼接操作
39丨深入理解数组:底层实现探究
40丨如何用数组来实现栈和队列
41丨Set:定义和创建
42丨Set:访问和修改
43丨Set:执行Set计算和判断
44 | 实现自己的集合算法
45 | 深入理解集合:底层实现探究
46 | Dictionary:Swift中的字典类型
47 | 字典的常见操作
48 | 深入理解字典:底层实现探究
49 | Swift中如何定义和使用函数
50 | 函数的形式参数和返回值
51 | 函数类型和内嵌函数
52 | 闭包和闭包表达式
53 | 闭包捕获值
54 | 逃逸闭包和自动闭包
55 | 如何使用Swift中的高阶函数
56 | 函数式编程(1)
57 | 函数式编程(2)
58 | Swift面向对象概述
59 | 枚举从此站起来了
60 | 如何为类、结构体以及枚举添加属性
61 | 如何为类、结构体以及枚举添加方法
62 | 像访问数组和字典一样访问类和结构体:下标和下标重载
63 | 如何进行类的初始化和反初始化
64 | 如何在Swift中实现继承
65 | 如何在Swift中实现多态和进行类型转换
66 | 如何为现有的类、结构体、枚举或协议添加新功能
67丨Swift中的协议
68丨协议和扩展
69丨面向协议编程初探(1)
70丨面向协议编程初探(2)
71丨泛型的发展历史与泛型的概述
72丨如何在Swift中定义泛型函数
73丨如何在Swift中定义泛型类型
74丨Swift泛型中的类型约束
75 | 为了协议:关联类型
76 | 如何为泛型定义要求:where字句
77 | 泛型下标
78丨泛型编程思想浅谈
79 | 如何在Swift中创建一个线程
80 | 更高级的抽象:Cocoa Operation
81丨多线程编程新思路:GCD概览
82 | 如何使用GCD:基本操作指南
83 | 深度使用GCD:高级特性指南
84 | 深入理解GCD:源码剖析
85 | 如何保证线程安全和同步
86 | 实践出真知:多线程典型应用场景分析
87 | 拓宽思路:其他常见的多线程编程模式
88 | SwiftUI:Apple全新的UI框架
89 | SwiftUI设计工具使用指南
90 | 如何使用SwiftUI构建可复用的组件
91 | 如何用SwiftUI实现动画
92 | 深入理解SwiftUI:实现原理探秘
93 | 如何在Swift里进行错误处理
94 | Swift中代码访问权限控制
95 | 不透明类型
96 | Swift中的自动引用计数
97 | Swift中的内存安全性
98 | 如何在项目中进行网络请求
99 | 如何进行JSON的序列化和反序列化
100 | 没有最方便,只有更方便:对Swift标准库的一些扩展
101 | 如何在Swift中进行自动布局
102 | 如何进行图片加载和缓存
103 | 以一种优雅安全的方式使用资源文件
104 | 如何在项目中将内容分享到社交平台
105 | Swift和Objective-C的运行时简介
106 | 桥接问题
107 | 如何在Swift和Objective-C中相互调用
108 | Swift和Objective-C混合编程踩坑指南
109 | 如何搭建一个iOS Swift工程
110 | 商城整体架构、UI设计和模块拆分
111 | 编写mock API
112 | 登录注册页模块开发
113 | 商城列表页模块开发
114 | 商城详情页模块开发
115 | 商城个人中心页模块开发
116 | 商城订单页模块开发
117 | 结束语
118|加餐1:可选链
119|加餐2:Swift KVC
120|加餐3:Swift面试中的要点注意事项&结课测试
登录 后留言

全部留言(12)

  • 最新
  • 精选
九三
老师, 函数式编程和链式编程看的挺像, 有什么区别吗

作者回复: 函数式编程是和面向对象编程并列的一种编程思想, 链式编程只要写起来是一个链条就可以,面向对象里你可以使用这种链的方式,函数式编程里也可以使用链式。 所以我觉得两个根本不是一回事,函数式编程是一种编程思想,链式编程是一种书写代码的方式。

2019-12-15
3
pengzishang
let source = "Hello world" let target = ["a","e","i","o","u"] let firstOrders = target.map { (character) -> Int? in let index = source.firstIndex(where: { String($0) == character }) return index?.utf16Offset(in: source) } print(zip(target, firstOrders.compactMap({$0 ?? -1})).map({$0})) 感觉还是不够简明扼要

作者回复: let source = "Hello world" let target: [Character] = ["a","e","i","o","u"] zip(0..<source.count, source).forEach { (index, char) in if target.contains(char) { print(index) } } 因为swift没有yield,所以不是很优雅

2019-10-15
3
王凯
let source = "Hello World" let target: [Character] = ["a", "e", "i", "o", "u"] print(zip(0..<source.count, source).first {target.contains($1)}?.0)
2020-04-15
3
Yarren
let source = "Hello world" let target: [Character] = ["a","e","i","o","u"] print(source.prefix{!target.contains($0)}.count)
2020-11-05
1
欢乐的小马驹
通过第二种方式,岂不是时间复杂度更高了?
2019-12-28
2
1
Geek_d004f7
zip(0..., "hello world").filter{ ["a", "e", "i", "o", "u"].contains(String($1)) }.first?.0
2022-01-26
风早
这个算法里面哪句是给wordDict的key赋值的呢 没发现呀 请指教~
2021-10-13
风早
func wordFreq(words:String) -> [String: Int] { var wordDict:[String: Int] = [:] let wordList = words.split(separator: " ") print("wordDict:\(wordDict)") for word in wordList { let lowerCaseWord = word.lowercased() if !NON_WORDS.contains(lowerCaseWord) { if let count = wordDict[lowerCaseWord]{ wordDict[lowerCaseWord] = count + 1 }else{ wordDict[lowerCaseWord] = 1 } } } print("wordDict:\(wordDict)") return wordDict; }
2021-10-13
Anrika
let source = "Hello World" let target: [Character] = ["a", "e", "i", "o", "u"] zip(0..<source.count, source).forEach { if target.contains($0.1) { print($0.0) } }
2020-04-21
Happy_Home
let source = "Hello world" var target: [Character] = ["a","e","i","o","u"] let result = zip([Character](source.map { $0 }),0 ..< source.count).filter { (char,index) -> Bool in //firstIndex表示已经尝试在target查找char的第一次出现的元素下标了 guard let currentIndex = target.firstIndex(of: char) else { //false时,即target中不包含此Character元素,则此时的char与index不会在新的集合中出现 return false } //发现元素下标后将target中已匹配的元素剔除掉,因为已经找到了,后续的char没必要再找了,不去处会被source重复的char覆盖掉下标 _ = target.remove(at: currentIndex) return true } print(result)
2020-04-18
收起评论