p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #007400; background-color: #ffffff }

nonatomic : 非原子属性

       

 

p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #007400; background-color: #ffffff }

atomic    : 原子属性  如果不写关键字 那么默认就是 原子属性

           – 多线程写入属性时,保证同一时间只有一个线程能够执行写入操作

           – 单(线程)写多(线程)读线程技术,同样有可能出现”脏数据”,重新读一下

       – 性能较慢

 

p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #007400; background-color: #ffffff }

线程安全

    在多个线程进行读写操作的时候,仍然能够保证数据正确

 

p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #007400; background-color: #ffffff }

UI线程(主线程) : 共同一个约定,所有更新UI的操作都在主线程上执行!

   原因:几乎所有的UIKit 都不是线程安全的!”取舍”为了性能!

 

 

p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #000000; background-color: #ffffff }
p.p2 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #007400; background-color: #ffffff }
p.p3 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #2e0d6e; background-color: #ffffff }
span.s1 { color: #5c2699 }
span.s2 { color: #000000 }
span.s3 { color: #c41a16 }
span.s4 { color: #aa0d91 }

使用 atomic 的场景 写入文件时

    NSData * data ;
    //原子属性 == YES  , 先把文件保存在一个临时的文件中,等全部写入之后,再改名
    [data writeToFile:@"xxx.mp4" atomically:YES];

 

p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #007400; background-color: #ffffff }
p.p2 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #007400; background-color: #ffffff; min-height: 16.0px }

 实际上,原子属性内部有一个锁,自旋锁

 自旋锁 & 互斥锁

 – 共同点:

    都能够保证线程安全.

 – 不同点:

    互斥锁:如果线程被锁在外面,就会进入休眠状态,等待锁打开,然后被唤醒!

    自旋锁:如果线程被锁在外面,就会用死循环的方式,一直等待锁打开!

 

 无论什么锁,都很消耗新能.效率不高

 

版权声明:本文为jukaiit原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/jukaiit/p/10032400.html