美文网首页
OC 多线程基础知识:进程、线程、并行、并发、线程的生命周期,互

OC 多线程基础知识:进程、线程、并行、并发、线程的生命周期,互

作者: 赵邦华 | 来源:发表于2020-11-08 23:29 被阅读0次

进程(process)

  • 就是一个运行的程序,比如一个运行的App。

  • 有独立的逻辑内存空间。

线程(thread)

  • 进程中一路单独运行的程序,一个进程由一个或多个线程构成。

  • 各线程共享相同的代码和全局数据,但各有其自己的堆栈。

进程和线程的关系

  • 进程之间的内存空间是独立的,同一进程的线程共享进程的内存空间。

  • 进程之间的资源(I/O,CPU)是独立的,同一进程的线程共享进程的资源。

  • 一个进程奔溃后,不影响其他进程。一个线程奔溃后,其对应的线程也会奔溃。

  • 线程切换比进程快。

  • 线程必须在进程中才能运行,一个进程知识拥有一个线程。

并行(parallel)

在一个时间点,几个线程同时进行,CPU数大于线程数。

并发(concurrent)

在一个时间段内,几个线程同时执行,如果CPU数小于线程数,并发是CPU在线程之间快速切换的结果,造成多线程并行的假象。

多线程

  • 同一时间内,多个线程同时进行。

  • 如果CPU数大于线程数,这是真正的并行

  • 如果CPU数小于线程数,这是并发,CPU在线程之间快速切换,照成并行的假象

线程的生命周期

OC 线程的生命周期.png
  • 当线程对象被创建后,调用start方法进入就绪状态(Runnable,也称为ready),此时线程加入可调度线程池等待执行。

  • CPU通过调度当前线程运行它,当线程运行完之后,结束线程。

  • CPU在调度线程过程中,CPU的多核机制(快速切换,并发执行)会调用其他线程同时执行。

  • 当一个线程正在运行过程中,如果调用了 Sleep 或者同步锁(@synchronized()),则会阻塞线程执行,这会将线程从可调度池中移出,当Sleep 或者同步锁(@synchronized()),会重新将线程加入可调度池进入就绪状态。

线程安全

在一个进程中,多个线程在同时执行,线程之间可能会访问同一地址空间资源,这样可能会导致数据错乱,需要一定的机制保证多线程访问资源的抢夺,这个机制就是锁,锁可以保证,同⼀时间,只有⼀条线程能够执⾏,从而可以确保该代码的正确性。

互斥锁 (pthread_mutex)

  • 如果共享数据已经有其他线程加锁了,线程会进入休眠状态等待锁。一旦被访问的资源被解锁,则等待资源的线程会被唤醒。

  • 互斥锁范围,应该尽量小;锁定范围越大,效率越差。

  • 能够给任意NSObject对象加锁。

自旋锁(OSSpinLock)

  • 与互斥锁(阻塞-睡眠)不同,自旋锁加锁后是进入忙等状态。

  • 如果共享数据已经有其他线程加锁了,线程会以忙等的方式等待锁,一旦被访问的资源被解锁,则等待资源的线程会立即执行。

  • OSSpinLock效率很高,但是已不再安全(如果一个低优先级的线程获得锁并访问共享资源,这时一个高优先级的线程也尝试获得这个锁,它会处于 spin lock 的忙等状态从而占用大量 CPU。)

相关文章

  • Python多线程与多进程

    内容简述: 线程与进程的相关概念1、程序,进程,线程,多进程,多线程2、线程的生命周期3、并行与并发,同步与异步4...

  • iOS - Multi-Thread

    概念篇 进程 线程 多线程 单核多线程 & 多核多线程 并行 & 并发 同步 & 异步 队列 队列 & 任务 的执...

  • python24-多线程和多进程基础

    本篇主要讲的是多线程和多进程的一些基础知识,包括并发、并行、进程、线程相关概念以及线程的创建与调用、阻塞线程和守护...

  • iOS 多线程技术总结

    概览 进程与线程的概念 多线程的由来 并行与并发 多线程的实现 串行与并行 线程的几种状态 串行队列与并发队列区别...

  • python网络爬虫:多任务-进程、线程

    一 、实现多任务的方式 多线程多进程协程多线程+多进程 并行,并发 并行:同时发起同时执行,(4核,4个任务)并发...

  • OC 多线程基础知识:进程、线程、并行、并发、线程的生命周期,互

    进程(process) 就是一个运行的程序,比如一个运行的App。 有独立的逻辑内存空间。 线程(thread) ...

  • 线程

    目录: 线程与进程的关系:什么叫“并发”?什么叫“并行”?多线程的好处:Java 的创建多线程的方法(三种):线程...

  • Python(2)---并发编程

    目录 1. Python多线程与多进程知识1.1 并发与并行1.2 线程(thread)与进程(process)...

  • Java多线程知识点汇总

    Java 多线程 多线程:指的是这个程序(一个进程)运行时产生了不止一个线程 并行与并发:并行:多个cpu实例或者...

  • java多线程-1-并发编程

    并行与并发 并发两个队伍排一个咖啡机单cpu,多线程 并行两个队伍排两个咖啡机多cpu,多线程 进程与线程 进程间...

网友评论

      本文标题:OC 多线程基础知识:进程、线程、并行、并发、线程的生命周期,互

      本文链接:https://www.haomeiwen.com/subject/uepkbktx.html