iOS多线程开发——NSThread浅析_IOS

  在iOS开发中,多线程的实现方式主要有三种,NSThread、NSOperation和GCD,我前面博客中对NSOperation和GCD有了较为详细的实现,为了学习的完整性,今天我们主要从代码层面来实现NSThread的使用。案例代码上传至 https://github.com/chenyufeng1991/NSThread。

(1)初始化并启动一个线程

  - (void)viewWillAppear:(BOOL)animated
  {
  [super viewWillAppear:animated];
  //获取当前线程
  NSThread *current = [NSThread currentThread];
  NSLog(@"当前线程为 %@",current);
  //初始化线程
  NSThread *thread = [[NSThread alloc] initWithTarget:self selector:@selector(run) object:nil];
  //设置线程的优先级(0.0-1.0)
  thread.threadPriority = 1.0;
  thread.name = @"新线程1";
  [thread start];
  }
  - (void)run
  {
  NSLog(@"线程执行");
  //获取当前线程
  NSThread *current = [NSThread currentThread];
  NSLog(@"当前线程为 %@",current);
  //线程休眠,可以模拟耗时操作
  [NSThread sleepForTimeInterval:2];
  //获取主线程
  NSThread *mainThread = [NSThread mainThread];
  NSLog(@"子线程中获得主线程 %@",mainThread);
  }

  其中currentThread,这个方法很有用,常常可以用来判断某方法的执行是在哪个线程中。

  (2)NSThread可以指定让某个线程在后台执行:


  //后台创建一个线程来执行任务,需要在调用的方法中使用自动释放池

  [self performSelectorInBackground:@selector(run3) withObject:nil];
  - (void)run3

  {

  @autoreleasepool {

  NSLog(@"主线程3:%@,当前线程3:%@",[NSThread mainThread],[NSThread currentThread]);

  }

  }

(3)子线程执行耗时操作,主线程更新UI。这是多线程开发中最常用的案例。子线程中调用performSelectorOnMainThread方法用来更新主线程。

//测试在子线程中调用主线程更新UI
- (void)viewWillAppear:(BOOL)animated
{
 [super viewWillAppear:animated];

 NSThread *subThread = [[NSThread alloc] initWithTarget:self selector:@selector(run) object:nil];
 //NSThread可以控制线程开始
 [subThread start];
}

- (void)run
{
 NSLog(@"主线程1:%@,当前线程1:%@",[NSThread mainThread],[NSThread currentThread]);
 //以下方法需要在子线程中调用
 [self performSelectorOnMainThread:@selector(invocationMainThread) withObject:nil waitUntilDone:YES];
}

- (void)invocationMainThread
{
 NSLog(@"主线程2:%@,当前线程2:%@",[NSThread mainThread],[NSThread currentThread]);
 NSLog(@"调用主线程更新UI");
}

  (4)同样,我们也可以新建一个子线程的类,继承自NSThread. 然后重写里面的main方法,main方法就是该线程启动时会执行的方法。

@implementation MyThread

- (void)main
{
 NSLog(@"main方法执行");
}

@end

  然后按正常的创建启动即可。线程就会自动去执行main方法。

//可以自己写一个子类,继承自NSThread,需要重写main方法
/**
 * 执行的代码是在main中的,而不是使用@selector.
 使用main方法,线程中执行的方法是属于对象本身的,这样可以在任何其他需要使用这个线程方法的地方使用,而不用再一次实现某个方法。

 而其他的直接NSThread的创建线程,线程内执行的方法都是在当前的类文件里面的。
 */
- (void)viewWillAppear:(BOOL)animated
{
 [super viewWillAppear:animated];

 MyThread *thread = [[MyThread alloc] init];
 [thread start];
}

  (5)NSThread中还有一个很常用的方法就是延迟。延迟2s执行。

 //线程休眠,可以模拟耗时操作
 [NSThread sleepForTimeInterval:2];

   对于多线程的三种实现方式,我们都要能够熟练使用

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索ios
, 多线程
nsthread
ios 多线程开发、ios开发面试题 多线程、ios多线程开发实例、ios nsthread、ios nsthread 使用,以便于您获取更多的相关知识。

时间: 2024-08-30 07:42:07

iOS多线程开发——NSThread浅析_IOS的相关文章

IOS多线程开发之线程的状态_IOS

大家都知道,在开发过程中应该尽可能减少用户等待时间,让程序尽可能快的完成运算.可是无论是哪种语言开发的程序最终往往转换成汇编语言进而解释成机器码来执行.但是机器码是按顺序执行的,一个复杂的多步操作只能一步步按顺序逐个执行.改变这种状况可以从两个角度出发:对于单核处理器,可以将多个步骤放到不同的线程,这样一来用户完成UI操作后其他后续任务在其他线程中,当CPU空闲时会继续执行,而此时对于用户而言可以继续进行其他操作:对于多核处理器,如果用户在UI线程中完成某个操作之后,其他后续操作在别的线程中继续

iOS多线程开发系列之(二)NSOperation

上一篇我们简单的对iOS多线程开发系列(一)三种多线程办法进行对比性能和操作的复杂度,并认真介绍了NSThread的使用. 我们借助上一次的例子完全可以采取NSOperation方法进行实现 NSOperation不具备封装操作的能力,必须使用它的子类: NSInvocationOperation NSBlockOperation 更简洁的Block实现方法,功能上与 NSInvocationOperation基本一致 自定义子类继承NSOperation,实现内部相应的方法 NSInvocat

iOS多线程开发之深入GCD

iOS多线程开发之深入GCD 一.前言         在以前的一些系列博客中,对iOS中线程的管理做了总结,其中涵盖了GCD的相关基础知识:http://my.oschina.net/u/2340880/blog/417746.那里面将GCD的线程管理能力,列队组能力,通过信号和消息控制程序流程的能力都有介绍,这里,我们继续深入GCD的功能,通过GCD来处理一些逻辑更加复杂的代码功能. 二.延时追加任务         当我们在程序中处理延时任务的时候,我们一般会通过两种方式,一种是通过定时器

IOS 多线程GCD详解_IOS

Grand Central Dispatch (GCD)是Apple开发的一个多核编程的解决方法. dispatch queue分成以下三种: 1)运行在主线程的Main queue,通过dispatch_get_main_queue获取. #definedispatch_get_main_queue() \DISPATCH_GLOBAL_OBJECT(dispatch_queue_t, _dispatch_main_q) 可以看出,dispatch_get_main_queue也是一种disp

iOS多线程开发系列之(三)Grand Central Dispatch(GCD)

上两篇介绍了NSThread和NSOperation的用法,这篇是对第三种多线程开发GCD的介绍 介绍: GCD是苹果公司在iOS4+以后推出的多线程技术,也是苹果着力推荐的,由于基于C语言开发的,所以它的高效性无与伦比的,但学习难度可能在其他两个之上. 创建串行队列 使用dispatch_queue_create函数 使用主队列:使用dispatch_get_main_queue()获得主队列 dispatch_queue_t dispatch_queue_create(const char

详解iOS多线程GCD的使用_IOS

Grand Central Dispatch(GCD)是异步执行任务的技术之一 dispatch queue分成以下三种: 1)运行在主线程的Main queue,通过dispatch_get_main_queue获取. /*! * @function dispatch_get_main_queue * * @abstract * Returns the default queue that is bound to the main thread. * * @discussion * In or

iOS时钟开发案例分享_IOS

本文实例为大家介绍了iOS时钟开发过程,供大家参考,具体内容如下 思路就是利用CALayer的隐式动画来实现.因为UIView的非根层也就是手动创建的layer在其属性发生变化时会默认会产生动画效果,这些属性也叫作可动画属性.比如bounds.backgroundColor.position. 时钟里面表盘就是一个UIView,而三根针就是三个手动创建的layer. 先在storyboard上弄一个UIImageView,设置表盘图片 然后在viewDidLoad中初始化三根针,并设置定时器,获

iOS多线程开发系列之(一)NSThread

什么是多线程? 一个进程的开始阶段系统会分配一个主线程进行正常的工作,工作过程中是依次执行的,只有这个任务执行完毕的时候才能执行下一个任务,两个或多个任务不能同时执行.这样的工作效率是低效的,因此就引入了多线程,能够利用iPhone设备多核的优势同时并发的处理多个事件. 三种多线程技术: 1.NSThread 2.NSOperation.NSOperationQueue 3.GCD 分析三种技术 这三种技术从上到下封装性逐步降低.造成逐步复杂.高效性逐步提升,GCD是基于C语言开发的,最底层.用

详解iOS 多线程 锁 互斥 同步_IOS

在iOS中有几种方法来解决多线程访问同一个内存地址的互斥同步问题: 方法一,@synchronized(id anObject),(最简单的方法) 会自动对参数对象加锁,保证临界区内的代码线程安全 @synchronized(self) { // 这段代码对其他 @synchronized(self) 都是互斥的 // self 指向同一个对象 } 方法二,NSLock NSLock对象实现了NSLocking protocol,包含几个方法: lock,加锁 unlock,解锁 tryLock