多线程常用术语

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了多线程常用术语相关的知识,希望对你有一定的参考价值。

线程同步:
  同步就是协同步调,按预定的先后次序进行运行。如:你说完,我再说。
  线程同步,可理解为线程A和B一块配合,A执行到一定程度时要依靠B的某个结果,于是停下来,示意B运行;B依言执行,再将结果给A;A再继续操作。
原子操作:
  一个函数或动作由一个或多个指令的序列实现,对外是不可见的;也就是说没有其他进程能看到其中间状态或中断此操作。
  要保证指令序列要么作为一个组来执行,要么都不执行。原子性保证了并发进程的隔离。
互斥:
  当一个进程在临界区访问共享资源时,其他进程不能进入该临界区访问共享资源的情形。
临界区:
  一段代码,在这段代码中进程将访问共享资源,当另外一个进程已在这段代码中运行时,这个进程就不能在这段代码中执行。
死锁:
  死锁定义为一组相互竞争系统资源或进行通信的进程间的"永久"阻塞。
形成死锁的四个条件:
  1 互斥;2 占有且等待;3 不可抢占;4 循环等待。
活锁:
  活锁指的是任务或者执行者没有被阻塞,由于某些条件没有满足,导致一直重复尝试->失败->尝试->失败。
活锁和死锁的区别:
  在于,处于活锁的实体是在不断的改变状态,所谓的“活”;而处于死锁的实体表现为等待;活锁有可能自行解开,死锁则不能。
饥饿:
  一个可运行进程尽管能继续执行,但被调用程序无限期的忽视,而不能被调度执行的情形。

 

以上是关于多线程常用术语的主要内容,如果未能解决你的问题,请参考以下文章

多线程 Thread 线程同步 synchronized

多个用户访问同一段代码

线程学习知识点总结

多个请求是多线程吗

python小白学习记录 多线程爬取ts片段

多线程常用基础