博客
关于我
iOS学习——锁
阅读量:617 次
发布时间:2019-03-13

本文共 743 字,大约阅读时间需要 2 分钟。

多线程开发中,资源竞争问题是一个常见且棘手的问题。尤其是在多个线程同时操作同一资源时,如果没有采取适当的措施,可能会导致数据混乱。售票系统的例子就很能说明问题。多个售票员同时卖票时,系统可能会出现票数重复出售的情况,这正是多线程带来的不安全性。

为了解决这个问题,我们需要使用同步机制。@synchronized是一个常用的方法,它通过锁定代码块,确保在同一时间只能有一个线程执行该代码。然而,需要注意的是,@synchronized所锁定的必须是一个全局变量,而不能是局部变量,因为局部变量在线程进入代码块后会立即被释放,导致锁失效。

互斥锁(互斥锁)的作用是确保在运行过程中,只有一个线程能够访问被锁定的代码块。其他线程则会在锁外等待,直到当前线程释放锁。这种机制保证了线程的原子性操作。然而,在大多数情况下,我们为了提高性能,会使用nonatomic属性,这会使得变量的访问变得不安全。

在文件操作中,原子性也是很重要的。例如,当使用NSFileHandle写入文件时,可以通过设置atomically:YES来确保操作的原子性。这样可以避免文件被删除或修改的情况出现。

对于资源保护,我们通常会定义一个全局锁。例如,可以声明一个atomic类型的锁,并通过@synchronized来同步访问。这样可以确保多个线程在访问锁定的资源时,彼此之间不会产生冲突。

然而,使用锁也会带来一些不便。锁会增加每次访问资源的开销,可能会影响程序的性能。在实际开发中,我们需要权衡资源的安全性和性能的需求。

总之,在多线程开发中,正确使用锁机制是确保资源安全的关键。通过合理设计和配置,我们可以在保证数据一致性的同时,尽量减少性能损失。这也是苹果在设计UIKit时采取线程不安全方式的原因之一。

转载地址:http://bokaz.baihongyu.com/

你可能感兴趣的文章
mysql interval显示条件值_MySQL INTERVAL关键字可以使用哪些不同的单位值?
查看>>
Mysql join原理
查看>>
MySQL Join算法与调优白皮书(二)
查看>>
Mysql order by与limit混用陷阱
查看>>
Mysql order by与limit混用陷阱
查看>>
mysql order by多个字段排序
查看>>
MySQL Order By实现原理分析和Filesort优化
查看>>
mysql problems
查看>>
mysql replace first,MySQL中处理各种重复的一些方法
查看>>
MySQL replace函数替换字符串语句的用法(mysql字符串替换)
查看>>
mysql replace用法
查看>>
Mysql Row_Format 参数讲解
查看>>
mysql select, from ,join ,on ,where groupby,having ,order by limit的执行顺序和书写顺序
查看>>
MySQL Server 5.5安装记录
查看>>
mysql server has gone away
查看>>
mysql slave 停了_slave 停止。求解决方法
查看>>
MySQL SQL 优化指南:主键、ORDER BY、GROUP BY 和 UPDATE 优化详解
查看>>
MYSQL sql语句针对数据记录时间范围查询的效率对比
查看>>
mysql sum 没返回,如果没有找到任何值,我如何在MySQL中获得SUM函数以返回'0'?
查看>>
mysql Timestamp时间隔了8小时
查看>>