在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
首先我们先搞清楚线程为什么是不安全和不同步的死锁死锁是指两个或两个以上的进程,在执行过程中,由于竞争资源或者由于彼此通信而造成的一种阻塞的现象,若无外力作用,他们都将无法推进下去,此时称系统处于死锁状态或差生了死锁 临界区这是一段代码不能被并发执行,也就是,两个线程不能同时执行这段代码 竞态条件两个或多个线程读写某些共享数据,而最后的结果取决于线程运行的精确时序。 比如同时操作一个余额 优先级反转低优先级获得了资源。高优先级尝试获得锁 高线程的就会被挂起 中优先级就释放了。 中不需要获取锁, 低挂起。低的速度比较慢。。所以锁一直得不到释放 中就运行的比较顺。。 高反而没有得到执行 并发与并行iso 锁的时间 OsspinLock效率最高。可能会产生死锁 @synchronized被移除了 SpinLock线程通过busy-wait-loop的方式来获取锁,任时刻只有一个线程能够获得锁,其他线程忙等待直到获得锁 下面是伪代码 SpinLock 临界区尽量短,控制在100行代码以内。不要有显式或者隐式的系统调用,调用的函数也尽量短 保证访问锁的线程全部都处于同一优先级。 Synchronized 只有传同样的对象给synchronized 才能起到加锁作用 如果是nil ,是无法起到加锁作用的 可以重入 synchronized 不会持有传给它的对象 进入方法 退出方法 SyncData 是可以重用的(threadCount == 0) 存在全局的map里
学到这里。。我仿佛看到了android ListView复用。。。
|
请发表评论