关于——NSThread

创建、启动线程

1 NSThread *thread = [[NSThread alloc] initWithTarget:self selector:@selector(run) object:nil];
2 [thread start];

主线程相关用法

1 + (NSThread *)mainThread; // 获得主线程
2 - (BOOL)isMainThread; // 是否为主线程
3 + (BOOL)isMainThread; // 是否为主线程

获得当前线程

NSThread *current = [NSThread currentThread];
线程的调度优先级
+ (double)threadPriority;
+ (BOOL)setThreadPriority:(double)p;
- (double)threadPriority;
- (BOOL)setThreadPriority:(double)p;

调度优先级的取值范围是0.0 ~ 1.0,默认0.5,值越大,优先级越高

线程的名字

- (void)setName:(NSString *)n;
- (NSString *)name;

其他创建线程方式↓

创建线程后自动启动线程

1 [NSThread detachNewThreadSelector:@selector(run) toTarget:self withObject:nil];

隐式创建并启动线程

1 [self performSelectorInBackground:@selector(run) withObject:nil];

上面两种创建线程方式的优缺点

优点:简单快捷

缺点:无法对线程进行更详细的设置

控制线程的状态

启动线程↓

1 - (void)start; 

阻塞(暂停线程)↓

1 + (void)sleepUntilDate:(NSDate *)date;
2 + (void)sleepForTimeInterval:(NSTimeInterval)ti;

强制停止线程

1 + (void)exit;

互斥锁使用格式

1 @synchronized(锁对象) { // 需要锁定的代码  }
2 //注意:锁定1份代码只用1把锁,用多把锁是无效的

互斥锁的优缺点

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

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

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

原子和非原子属性

OC在定义属性时有nonatomic和atomic两种选择
atomic:原子属性,为setter方法加锁(默认就是atomic)
nonatomic:非原子属性,不会为setter方法加锁
 
nnonatomic和atomic对比
atomic:线程安全,需要消耗大量的资源
nonatomic:非线程安全,适合内存小的移动设备
 
iOS开发的建议
所有属性都声明为nonatomic
尽量避免多线程抢夺同一块资源
尽量将加锁、资源抢夺的业务逻辑交给服务器端处理,减小移动客户端的压力

 线程间通信常用方法

1  - (void)performSelectorOnMainThread:(SEL)aSelector withObject:(id)arg waitUntilDone:(BOOL)wait;
2  - (void)performSelector:(SEL)aSelector onThread:(NSThread *)thr withObject:(id)arg waitUntilDone:(BOOL)wait;

 如果你发现错误,或者有更好的代码,烦请评论或者私信告诉我。

原文地址:https://www.cnblogs.com/0511fa/p/5002736.html