1. 多线程的安全隐患



  • 资源共享



  1块资源可能会被多个线程共享,也就是多个线程可能会访问同一块资源

  比如多个线程访问同一个对象、同一个变量、同一个文件



  • 当多个线程访问同一块资源时,很容易引发数据错乱和数据安全问题

2. 安全隐患解决方案 – 互斥锁

  苹果不建议使用互斥锁,因为太消耗性能

(1) 互斥锁使用格式

// 需要锁定的代码

注意:锁定1份代码只用1把锁,用多把锁是无效的

(2) 互斥锁的优缺点

  优点: 能有效防止因多线程抢夺资源造成的数据安全问题

  缺点: 需要消耗大量的CPU资源

(3) 互斥锁的使用前提: 多条线程抢夺同一块资源

(4) 相关专业术语: 线程同步

  线程同步的意思是: 多条线程按顺序地执行任务

  互斥锁,就是使用了线程同步技术



// 互斥锁,要在抢夺的共享资源读写范围上加锁
// 增加互斥锁之后,并发的整体性能“会下降”
// 互斥锁对性能影响是相当严重的,代价是高昂的!
// 在使用互斥锁的时候,一定注意,尽量减少锁定的代码范围
    @synchronized(self) {



3. 在开发多线程的时候, 永远不要相信一次的运行结果

4. 原子属性和互斥锁

只允许一个线程对该属性进行写入操作, 可以允许多个线程读取属性数值!

  在定义属性时, 默认都是 atomic 属性

原子属性的性能, 比互斥锁高, 但是仍然代价很高! 不建议使用!

5. 原子属性和非原子属性

  OC在定义属性时有nonatomic和atomic两种选择

  atomic:原子属性,为setter方法加锁(默认就是atomic)

  nonatomic:非原子属性,不会为setter方法加锁

6. 原子属性和非原子属性的选择

(1) nonatomic和atomic对比

  atomic:线程安全,需要消耗大量的资源

  nonatomic:非线程安全,适合内存小的移动设备



(2) iOS开发的建议

  所有属性都声明为nonatomic

  尽量避免多线程抢夺同一块资源

  尽量将加锁、资源抢夺的业务逻辑交给服务器端处理,减小移动客户端的压力