函数响应式编程
函数式编程
函数式编程FP(Functional Programming)
,是一种抽象程度很高的编程范式,将计算机的运算看做是数学中的函数计算,最大的特点就是,可以将函数本身作为参数传入另一个函数,主要思想是把运算过程尽量写成一系列嵌套的函数调用,
比如: y = f(x) --------- x = f(x) -------- y = f(f(x))
举个例子
计算 (1 + 2) * 3 - 4 的结果
- 普通写法
int a = 1 + 2
int b = a * 3
int result = b - 4
- 函数式写法
func add(x: int, y: int) -> int{
return x + y
}
func multiply(x: int ,y: int) -> int{
return x * y
}
func subtract(x: int ,y: int) -> int{
return x - y
}
let result = subtract(multiply(add(1,2), 3), 4)
相比普通写法,函数式优点:
- 层次更加清晰
- 复用性高
- 可读性高
- 更加简洁
响应式编程
响应式编程 简称 RP(Reactive Programming)
,它是一种面向数据流和变化传播的编程方式。这意味着可以在编程语言中很方便地表达静态或者动态的数据流,而相关的计算模型会自动将变化的值通过数据流进行传播。响应式编程 与 函数式编程 相结合起来,就是 函数式响应编程
类似于iOS中的kvo, 比如一个计算结果, x = y + z ,x 赋值一次之后 y和z的值改变之后不会影响a的值. 那么响应式中 a 和 y+z 是绑定的,y或者z发生改变,x值也会受到影响,例如在我们实际开发中,
tableview
显示内容跟datasource的关系,普通开发方式下,数据请求成功得到数据然后手动刷新tableview
,但是在响应式编程中,请求到数据之后tableview
自动进行刷新
这个时候RXSwift的优势就展现出来了
RXSwift
ReactiveX(简写: Rx) 是一个可以帮助我们简化异步编程的框架。
RxSwift 是 Rx 的 Swift 版本。
ReactiveX 不仅仅是一个编程接口,它是一种编程思想的突破,它影响了许多其它的程序库和框架以及编程语言。它拓展了观察者模式,使你能够自由组合多个异步事件,而不需要去关心线程,同步,线程安全,并发数据以及I/O阻塞
先体验一下RX
的爽
一: button点击
- 传统实现
button.addTarget(self, action: #selector(buttonTapped), for: .touchUpInside)
func buttonTapped() {
print("button Tapped")
}
- RX实现
button.rx.tap
.subscribe(onNext: {
print("button Tapped")
})
.disposed(by: disposeBag)
二: textFiled 输入
self.textFiled.rx.text.orEmpty.changed.subscribe(onNext: { (text) in
print("监听到了 - \(text)")
}).disposed(by: disposeBag)
三: KVO
person.rx.observeWeakly(String.self, "name").subscribe(onNext: { (change) in
print(change ?? "helloword")
}).disposed(by: disposeBag)
四: 手势
let tap = UITapGestureRecognizer()
self.label.addGestureRecognizer(tap)
self.label.isUserInteractionEnabled = true
tap.rx.event.subscribe { (event) in
print("点了label")
}.disposed(by: disposeBag)
五: 定时器
timer = Observable<Int>.interval(1, scheduler: MainScheduler.instance)
timer.subscribe(onNext: { (num) in
print("hello word \(num)")
}).disposed(by: disposeBag)
//RxSwift实现的timer免去了我们计时器的一些不必要的麻烦
//runloop影响
//销毁问题
//线程问题
六: 通知
NotificationCenter.default.rx
.notification(UIResponder.keyboardWillShowNotification)
.subscribe { (event) in
print(event)
}.disposed(by: disposeBag)
不需要使用 Target Action,这样使得代码逻辑清晰可见。爽的一批