iOS多线程_02_多线程的安全问题
2014-08-22 16:53
197 查看
1. 多线程的安全隐患
资源共享1块资源可能会被多个线程共享,也就是多个线程可能会访问同一块资源
比如多个线程访问同一个对象、同一个变量、同一个文件
当多个线程访问同一块资源时,很容易引发数据错乱和数据安全问题
2. 安全隐患解决方案 – 互斥锁
苹果不建议使用互斥锁,因为太消耗性能(1) 互斥锁使用格式
@synchronized(锁对象) { // 需要锁定的代码 }
注意:锁定1份代码只用1把锁,用多把锁是无效的
(2) 互斥锁的优缺点
优点: 能有效防止因多线程抢夺资源造成的数据安全问题
缺点: 需要消耗大量的CPU资源
(3) 互斥锁的使用前提: 多条线程抢夺同一块资源
(4) 相关专业术语: 线程同步
线程同步的意思是: 多条线程按顺序地执行任务
互斥锁,就是使用了线程同步技术
// 互斥锁,要在抢夺的共享资源读写范围上加锁 // 增加互斥锁之后,并发的整体性能“会下降” // 互斥锁对性能影响是相当严重的,代价是高昂的! // 在使用互斥锁的时候,一定注意,尽量减少锁定的代码范围 @synchronized(self) {
3. 在开发多线程的时候, 永远不要相信一次的运行结果
4. 原子属性和互斥锁
原子属性 atomic 是苹果的一个多线程技术, 任何时候, 只允许一个线程对该属性进行写入操作, 可以允许多个线程读取属性数值!在定义属性时, 默认都是 atomic 属性
原子属性的性能, 比互斥锁高, 但是仍然代价很高! 不建议使用!
5. 原子属性和非原子属性
OC在定义属性时有nonatomic和atomic两种选择atomic:原子属性,为setter方法加锁(默认就是atomic)
nonatomic:非原子属性,不会为setter方法加锁
6. 原子属性和非原子属性的选择
(1) nonatomic和atomic对比atomic:线程安全,需要消耗大量的资源
nonatomic:非线程安全,适合内存小的移动设备
(2) iOS开发的建议
所有属性都声明为nonatomic
尽量避免多线程抢夺同一块资源
尽量将加锁、资源抢夺的业务逻辑交给服务器端处理,减小移动客户端的压力
相关文章推荐
- iOS 多线程编程的安全问题
- iOS 多线程~安全问题
- iOS开发--iOS多线程操作时一些要注意的安全问题
- iOS多线程全套:线程安全问题,GCD的使用,NSOperation的使用
- 多线程安全问题
- 多线程安全问题案例1 单例注入的类中含非线程安全属性
- mysql的多线程安全问题:在mysql_real_connect时出现段错误。
- STL的多线程安全问题
- Servlet多线程安全问题
- iOS上Sqlite多线程问题
- 静态方法的多线程安全问题
- Servlet容器之安全多线程问题
- SOCKET是多线程安全的吗? [问题点数:40分,结帖人CSDN]
- iOS (objective-c) 中的多线程互斥同步问题
- Java 学习笔记16:用ThreadLocal解决多线程安全问题
- 多线程的运行安全问题
- Servlet多线程安全问题
- Servlet多线程安全问题
- 自己实现的STL(试图解决多线程的安全问题)
- servlet多线程安全问题(转)