iOS中多线程的入门使用教程(Swift)

目录
  • 一、iOS的三种多线程技术
  • 二、基本使用
    • NSThread的基本使用
    • NSOperation的基本使用
    • GCD的基本使用
  • 总结

一、iOS的三种多线程技术

1、NSThread

–优点:NSThread 比其他两个轻量级,使用简单

–缺点:需要自己管理线程的生命周期、线程同步、加锁、睡眠以及唤醒等。线程同步对数据的加锁会有一定的系统开销

2、NSOperation

不需要关心线程管理,数据同步的事情,可以把精力放在自己需要执行的操作上

3、GCD

基于C语言的

二、基本使用

NSThread的基本使用

方式一:

//        block
        let thread =  Thread.init {
                print("1、----this is thread \(Thread.current) ")
        }
        thread.start()

方式二:

//        SEL
        let thread2 = Thread.init(target: self, selector: #selector(text), object: nil)
        thread2.start()
    @objc func text(){
        print("2、----this is thread \(Thread.current) ")
    }

方式三:\

 self.performSelector(inBackground: #selector(text2), with: nil)

输出

tips:可以给任意一个线程增加延迟看看

   print(thread.isCancelled)//是否取消
   print(thread.isExecuting)//是否在执行
   print(thread.isFinished)//是否完成
   print(thread.isMainThread)//是否是主线程

NSOperation的基本使用

方式一:

      let queue = OperationQueue.init()
//     最大线程数
        queue.maxConcurrentOperationCount = 2
        queue.addOperation {
            sleep(1)
            print("1111")
        }
        queue.addOperation {
            print("2222")
        }

输出结果如下:

方式二:可设置优先级

        let queue = OperationQueue.init()
      	let op =  BlockOperation.init {
            print("op")
        }
        op.queuePriority = .normal //设置优先级
        queue.addOperation(op)
        let op2 = BlockOperation.init {
            print("op2")
        }
        op2.queuePriority = .normal
        queue.addOperation(op2)

        queue.addOperation {
            print("op3")
        }

略作修改

        let queue = OperationQueue.init()
        let op =  BlockOperation.init {
            sleep(1)
            print("op")
        }
        op.queuePriority = .normal //设置优先级
        queue.addOperation(op)
        let op2 = BlockOperation.init {
            sleep(1)
            print("op2")
        }
        op2.queuePriority = .veryHigh
        queue.addOperation(op2)

        queue.addOperation {
            print("op3")
        }

输出如下:

优先级如下:

GCD的基本使用

方式一:queue.async 异步

   let queue =   DispatchQueue.init(label: "com.zjb.concurrent",attributes: .concurrent)
        for i in 0...15 {
            queue.async {
                sleep(1)
                print("this is \(Thread.current) \(i)")
            }
        }

方式二:queue.sync 同步

  let queue =   DispatchQueue.init(label: "com.zjb.concurrent",attributes: .concurrent)
        for i in 0...15 {
            queue.sync {
                sleep(1)
                print("this is \(Thread.current) \(i)")
            }
        }

附加网络上一段代码

        for i in 1...10 {
               DispatchQueue.global(qos: DispatchQoS.QoSClass.default).async {
                   NSLog("DispatchQoS.QoSClass.default, %d", i)
               }

               DispatchQueue.global(qos: DispatchQoS.QoSClass.background).async {
                   NSLog("DispatchQoS.QoSClass.background, %d", i)
               }

               DispatchQueue.global(qos: DispatchQoS.QoSClass.unspecified).async {
                   NSLog("DispatchQoS.QoSClass.unspecified, %d", i)
               }

               DispatchQueue.global(qos: DispatchQoS.QoSClass.userInitiated).async {
                   NSLog("DispatchQoS.QoSClass.userInitiated, %d", i)
               }

               DispatchQueue.global(qos: DispatchQoS.QoSClass.userInteractive).async {
                   NSLog("DispatchQoS.QoSClass.userInteractive, %d", i)
               }

               DispatchQueue.global(qos: DispatchQoS.QoSClass.utility).async {
                   NSLog("DispatchQoS.QoSClass.utility, %d", i)
               }
        }

优先级userInteractive最高、background最低

总结

到此这篇关于iOS中多线程入门使用的文章就介绍到这了,更多相关iOS多线程使用内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

时间: 2021-11-28

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

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

IOS多线程编程的3种实现方法

前言 在多线程简介中,我已经说明过了,为了提高界面的流畅度以及用户体验.我们务必要把耗时的操作放到别的线程中去执行,千万不要阻塞主线程. iOS中有以下3种多线程编程方法: NSThread Grand Centeral Dispatch(GCD) NSOperation和NSOperationQueue 1.NSThread 这是最轻量级的多线程的方法,使用起来最直观的多线程编程方法.但是因为需要自己管理线程的生命周期,线程同步.经常使用NSThread进行调试,在实际项目中不推荐使用. //

IOS多线程编程NSThread的使用方法

IOS多线程编程NSThread的使用方法 NSThread是多线程的一种,有两种方法创建子线程 (1)优点:NSThread 比GCD.NSOperation都轻量级 (2)缺点:需要自己管理线程的生命周期,线程同步.线程同步对数据的加锁会有一定的系统开销 第一种是隐藏创建,有以下几种方式: (1)多用于串行:- (id)performSelector:(SEL)aSelector withObject:(id)object; (2)后台执行,多用于并行:- (void)performSele

iOS中常见的几种加密方法总结

前言 在我们日常开发中,加密是必不可少的一部分,而普通加密方法是讲密码进行加密后保存到用户偏好设置中,钥匙串是以明文形式保存,但是不知道存放的具体位置,下面本文将详细给大家介绍iOS中常见的几种加密方法,下面话不多说了,来一起看看详细的介绍吧. 一. base64加密 base64 编码是现代密码学的基础 基本原理: 原本是 8个bit 一组表示数据,改为 6个bit一组表示数据,不足的部分补零,每 两个0 用 一个 = 表示 用base64 编码之后,数据长度会变大,增加了大约 1/3 左右.

Python中多线程的创建及基本调用方法

1. 多线程的作用 简而言之,多线程是并行处理相互独立的子任务,从而大幅度提高整个任务的效率. 2. Python中的多线程相关模块和方法 Python中提供几个用于多线程编程的模块,包括thread,threading和Queue等 thread模块提供了基本的线程和锁的支持,除产生线程外,也提供基本的同步数据结构锁对象,其中包括: start_new_thread(function, args kwargs=None)  产生一个新的线程来运行给定函数 allocate_lock()  分配

在IOS中为什么使用多线程及多线程实现的三种方法

多线程是一个比较轻量级的方法来实现单个应用程序内多个代码执行路径. 在系统级别内,程序并排执行,程序分配到每个程序的执行时间是基于该程序的所需时间和其他程序的所需时间来决定的. 然而,在每个程序内部,存在一个或者多个执行线程,它同时或在一个几乎同时发生的方式里执行不同的任务. 概要提示: iPhone中的线程应用并不是无节制的,官方给出的资料显示,iPhone OS下的主线程的堆栈大小是1M,第二个线程开始就是512KB,并且该值不能通过编译器开关或线程API函数来更改,只有主线程有直接修改UI

Python多线程编程(四):使用Lock互斥锁

前面已经演示了Python:使用threading模块实现多线程编程二两种方式起线程和Python:使用threading模块实现多线程编程三threading.Thread类的重要函数,这两篇文章的示例都是演示了互不相干的独立线程,现在我们考虑这样一个问题:假设各个线程需要访问同一公共资源,我们的代码该怎么写? 复制代码 代码如下: ''' Created on 2012-9-8   @author: walfred @module: thread.ThreadTest3 '''  impor

Python多线程编程(二):启动线程的两种方法

在Python中我们主要是通过thread和threading这两个模块来实现的,其中Python的threading模块是对thread做了一些包装的,可以更加方便的被使用,所以我们使用threading模块实现多线程编程.一般来说,使用线程有两种模式,一种是创建线程要执行的函数,把这个函数传递进Thread对象里,让它来执行:另一种是直接从Thread继承,创建一个新的class,把线程执行的代码放到这个新的 class里. 将函数传递进Thread对象 复制代码 代码如下: '''  Cr

iOS多线程应用开发中使用NSOperation类的基本方法

一.NSOperation简介 1.简单说明 NSOperation的作⽤:配合使用NSOperation和NSOperationQueue也能实现多线程编程 NSOperation和NSOperationQueue实现多线程的具体步骤: (1)先将需要执行的操作封装到一个NSOperation对象中 (2)然后将NSOperation对象添加到NSOperationQueue中 (3)系统会⾃动将NSOperationQueue中的NSOperation取出来 (4)将取出的NSOperati

java 多线程的三种构建方法

java  多线程的三种构建方法 继承Thread类创建线程类 public class Thread extends Object implements Runnable 定义Thread类的子类,并重写其run()方法 创建Thread子类的实例,即创建了线程对象 调用线程对象的start()方法启动线程 public class FirstThread extends Thread { public void run(){ for(int i=0;i<100;i++){ /* * Thre

nodejs中使用多线程编程的方法实例

在以前的博文别说不可能,nodejs中实现sleep中,我向大家介绍了nodejs addon的用法.今天的主题还是addon,继续挖掘c/c++的能力,弥补nodejs的弱点. 我曾多次提到过nodejs的性能问题.其实就语言本身而言,nodejs的性能还是很高的,虽然不及大多部静态语言,但差距也并不大:相对其他动态语言而言,速度优势非常明显.但为什么我们常常说nodejs不能胜任CPU密集型场景呢?因为由于其单线程特性,对于CPU密集型场景,它并不能充分利用CPU.计算机科学中有一个著名的A