IOS多线程开发-NSThread原理及演示








// 创建线程方式1
- (
void )test1
{
   
// 实例化一个线程对像
    NSThread *thread = [[NSThread alloc] initWithTarget:self selector:@selector(run) object:nil];
    // 让线程开始工作,启动线程, 在新开的线程执行run方法
    [thread start];
}

// 创建线程方式2
- (
void )test2
{
   
NSLog ( @"---%@" , [ NSThread currentThread ]);
    [NSThread detachNewThreadSelector:@selector(run:) toTarget:self withObject:@"hello"];
}

// 创建线程方式3
- (
void )test3
{
   
// “隐式”创建线程方式
    [
self performSelectorInBackground : @selector (run:) withObject : @"cz" ];
}

#pragma mark - 线程的属性
- ( void )test4
{
    NSThread *threadA = [[NSThread alloc] initWithTarget:self selector:@selector(run:) object:@"hello"];
    threadA. name = @"thraed A" ;

    // 线程优先级
   
// 是一个浮点数,0.0~1.0。 默认值 0.5
   
// 开发的时候,一般不去修改优先级的值。
   
// 优先级,必须调用很多次的时候,才能体现出来。
    threadA.threadPriority = 0.1;

    // 开始工作
    [threadA start];
}


//  NSThread线程的状态
- ( void )run
{
   
NSLog ( @"%s" , __func__);
   
   
// 刚进来就睡会, 睡2秒
//    [NSThread sleepForTimeInterval:5.0];
   
   
// 睡到指定的时间点
//    [NSThread sleepUntilDate:[NSDate dateWithTimeIntervalSinceNow:5.0]];
   
   
for ( int i = 0 ; i < 20 ; i++) {
       
       
// 满足某一个条件以后,阻塞线程的执行。 也就是让线程休息一会
       
if (i == 10 ) {
            [
NSThread sleepForTimeInterval : 3.0 ];
        }
       
       
// 一旦达到某一个条件,就强制终止线程的执行
       
if (i == 15 ) {
           
// 一旦强制终止,就在不能重新启动
           
// 一旦强制终止,后面的代码都不会执行
            [
NSThread exit ];
        }
       
       
NSLog ( @"%@--- %d" , [ NSThread currentThread ], i);
    }
   
   
NSLog ( @"线程结束" );
}

    // 把数据传到主线程,在主线程更新UI
     1 . [ self performSelectorOnMainThread : @selector (downloadFinish:) withObject :image waitUntilDone : NO ];

    2. [ self performSelector: @selector (downloadFinish:) onThread:[NSThread mainThread] withObject:image waitUntilDone: NO ];

    3.[self.iconView performSelectorOnMainThread:@selector(setImage:) withObject:image waitUntilDone:YES];


// nonatomic 非原子属性
// atomic 原子属性--默认属性
// 原子属性就是针对多线程设计的。 原子属性实现 单(线程)写 多(线程)读
// 因为写的安全级别要求更高。 读的要求低一些,可以多读几次来保证数据的正确性

    // 原子属性内部使用的 自旋锁
   
// 自旋锁和互斥锁
   
// 共同点: 都可以锁定一段代码。 同一时间, 只有线程能够执行这段锁定的代码
   
// 区别:互斥锁,在锁定的时候,其他线程会睡眠,等待条件满足,再唤醒
    // 自旋锁,在锁定的时候, 其他的线程会做死循环,一直等待这条件满足,一旦条件满足,立马去执行,少了一个唤醒过程
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值