swift 如何保证线程安全和同步

首先我们先搞清楚线程为什么是不安全和不同步的

死锁

死锁是指两个或两个以上的进程,在执行过程中,由于竞争资源或者由于彼此通信而造成的一种阻塞的现象,若无外力作用,他们都将无法推进下去,此时称系统处于死锁状态或差生了死锁

swift 如何保证线程安全和同步_第1张图片

临界区

这是一段代码不能被并发执行,也就是,两个线程不能同时执行这段代码

竞态条件

两个或多个线程读写某些共享数据,而最后的结果取决于线程运行的精确时序。

比如同时操作一个余额

优先级反转

swift 如何保证线程安全和同步_第2张图片

低优先级获得了资源。高优先级尝试获得锁  高线程的就会被挂起  中优先级就释放了。 中不需要获取锁,

低挂起。低的速度比较慢。。所以锁一直得不到释放 中就运行的比较顺。。 高反而没有得到执行

并发与并行

swift 如何保证线程安全和同步_第3张图片

iso 锁的时间

swift 如何保证线程安全和同步_第4张图片

OsspinLock效率最高。可能会产生死锁

@synchronized被移除了

SpinLock

线程通过busy-wait-loop的方式来获取锁,任时刻只有一个线程能够获得锁,其他线程忙等待直到获得锁

下面是伪代码

swift 如何保证线程安全和同步_第5张图片

SpinLock

临界区尽量短,控制在100行代码以内。不要有显式或者隐式的系统调用,调用的函数也尽量短

保证访问锁的线程全部都处于同一优先级。

Synchronized

swift 如何保证线程安全和同步_第6张图片

只有传同样的对象给synchronized 才能起到加锁作用

如果是nil ,是无法起到加锁作用的

可以重入

synchronized 不会持有传给它的对象

进入方法

swift 如何保证线程安全和同步_第7张图片

退出方法

swift 如何保证线程安全和同步_第8张图片

SyncData 是可以重用的(threadCount == 0)

存在全局的map里

 

swift 如何保证线程安全和同步_第9张图片

swift 如何保证线程安全和同步_第10张图片

swift 如何保证线程安全和同步_第11张图片

swift 如何保证线程安全和同步_第12张图片

swift 如何保证线程安全和同步_第13张图片

swift 如何保证线程安全和同步_第14张图片

学到这里。。我仿佛看到了android ListView复用。。。

 

你可能感兴趣的:(#,swift)